亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
1234下一頁
最近訪問板塊 發(fā)新帖
查看: 78045 | 回復: 34
打印 上一主題 下一主題

[其他] 事件響應方式 [復制鏈接]

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2016-08-12 11:26 |只看該作者 |倒序瀏覽
在編程中,常常要讓程序等待某些事件,如何及時響應這些事件,有若干方式。
1.        程序輪詢,程序不斷查詢狀態(tài),直到期望的狀態(tài)發(fā)生。這將劇烈消耗CPU和相關資源?梢栽谳喸冎胁迦雜leep之類的休眠以減小CPU的消耗,但是犧牲了響應時間。
2.        事件觸發(fā),有幾種:
1:1    一個線程等待一個事件,同步阻塞方式。等待期間不消耗CPU,事件可以立即響應。如read。
M:1    一個線程等待M個事件。同步阻塞方式。等待期間不消耗CPU,出現(xiàn)任一事件可以立即響應。如select。
M:N    N個線程等待M個事件。同步阻塞方式。等待期間不消耗CPU,出現(xiàn)任一事件都會選出一個線程來響應這個事件。如epoll。

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術圖書徽章
日期:2016-07-19 13:54:03程序設計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
2 [報告]
發(fā)表于 2016-08-12 17:30 |只看該作者
只討論 rpc 的情況?
不考慮跨硬件 rpc 的話,除了socket/pipe,還有信號量,條件量,直接回調(有競爭就加鎖)配著隊列之類的也方便

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
3 [報告]
發(fā)表于 2016-08-12 21:31 |只看該作者
本帖最后由 yulihua49 于 2016-08-12 21:33 編輯
cokeboL 發(fā)表于 2016-08-12 17:30
只討論 rpc 的情況?
不考慮跨硬件 rpc 的話,除了socket/pipe,還有信號量,條件量,直接回調(有競爭就加 ...

把你的想法說說,補充一下。

尤其是同步阻塞的事件處理器如何處理異步IO,沒想出來怎樣簡練的描述。
關于eventfd,signalfd,timerfd等等。

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術圖書徽章
日期:2016-07-19 13:54:03程序設計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
4 [報告]
發(fā)表于 2016-08-15 14:32 |只看該作者
最近論壇上的少,才看到。

eventfd這個好像沒什么可說的吧,epollfd,就是epoll那幾個接口
signalfd,這個具體是指信號?比如kill -9?還是指其他?
實現(xiàn)timer的方式也挺多的,timerfd這個也沒明白具體指?

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術圖書徽章
日期:2016-07-19 13:54:03程序設計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
5 [報告]
發(fā)表于 2016-08-15 14:42 |只看該作者
如果非要用c/c++

異步IO
發(fā)包肯定要存隊列,同步阻塞的地方處理,也只是把包掛到sock fd對應的結構體的消息隊列里然后加個等待可寫的事件,但是無法保證同步阻塞的地方返回時包已經(jīng)發(fā)出去了,
想等到結果,就得把同步的地方分兩半,發(fā)包之后的部分弄個回調來做,如果同步這部分邏輯,發(fā)包和等待都是在循環(huán)里,又不行,還得改成回調之后再激發(fā)下一次循環(huán)的結構,
所以你們各位弄的協(xié)程那種,可能比這種寫法稍好一些
如果同步的地方都用同步發(fā)肯定太虐心了,一是發(fā)包的sock fd如果有多個,就都應該從epoll列表里dele了先,然后再遍歷阻塞發(fā),這種肯定就亂了,不行

論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術圖書徽章
日期:2016-07-19 13:54:03程序設計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
6 [報告]
發(fā)表于 2016-08-15 14:50 |只看該作者
timer c/c++ epoll這種結構里
我見過的主流大概就兩種:
一種是弄個小頂堆或者list、map也湊合用,epoll的循環(huán)里每次wait最小時間間隔,nginx好像是這種,redis類似但是好像是沒用小頂堆,用的鏈表,我猜是redis的業(yè)務場景,簡單的鏈表實現(xiàn)足夠了吧
另一種是wait固定的tick time,然后和timer的結構最小間隔對比看到時間沒,就相當于輪詢吧


論壇徽章:
36
子鼠
日期:2013-08-28 22:23:29黃金圣斗士
日期:2015-12-01 11:37:51程序設計版塊每日發(fā)帖之星
日期:2015-12-14 06:20:00CU十四周年紀念徽章
日期:2015-12-22 16:50:40IT運維版塊每日發(fā)帖之星
日期:2016-01-25 06:20:0015-16賽季CBA聯(lián)賽之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16賽季CBA聯(lián)賽之福建
日期:2016-04-07 11:25:2215-16賽季CBA聯(lián)賽之青島
日期:2016-04-29 18:02:5915-16賽季CBA聯(lián)賽之北控
日期:2016-06-20 17:38:50技術圖書徽章
日期:2016-07-19 13:54:03程序設計版塊每日發(fā)帖之星
日期:2016-08-21 06:20:00
7 [報告]
發(fā)表于 2016-08-15 14:53 |只看該作者
不太清楚你們具體的業(yè)務場景,各種ipc機制和鎖這些,就像過家家,不同的業(yè)務場景和需求,可以有太多中擺法。。

可惜你們不用golang,否則真是簡化了太多結構,chan、鎖、回調加起來的各種組合,就差不多能搞所有姿勢了,省心,省力。

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
8 [報告]
發(fā)表于 2016-08-15 16:07 |只看該作者
本帖最后由 yulihua49 于 2016-08-15 16:16 編輯
cokeboL 發(fā)表于 2016-08-15 14:53
不太清楚你們具體的業(yè)務場景,各種ipc機制和鎖這些,就像過家家,不同的業(yè)務場景和需求,可以有太多中擺法。 ...

個人偏愛C是因為癖好,喜歡玩機器,C更像在使用一個機器。其他語言更高級,接近于任務描述,應該是好用些,但是資源控制更間接,有時不知他怎么干的,需要優(yōu)化也無從下手。

那幾個fd,你在網(wǎng)上搜搜,有詳細說明。配合epoll完成非IO異步操作的。
這里有一個eventfd配合epoll進行文件異步IO的例子:

  1. /*******************************************
  2. * 需要linux 2.6.22 以上版本
  3. * 和libaio 3.107以上版本
  4. * 如果不具備這個條件,在makefile里用SIO_fd.o
  5. * 取代本模塊
  6. *******************************************/

  7. #include <unistd.h>
  8. #include <sys/stat.h>
  9. #include <fcntl.h>
  10. #include <sys/eventfd.h>
  11. #include <libaio.h>

  12. #include <scsrv.h>

  13. static int AIO_oper(int fd,char *buff,size_t iosize,int flg)
  14. {
  15. io_context_t myctx;
  16. int rc,num;
  17. uint64_t finished_aio;
  18. struct iocb _iocb,*io=&_iocb;
  19. struct io_event event;
  20. int     efd = eventfd(0, 0);
  21. T_YIELD yield=get_yield();

  22.         if (efd == -1) {   
  23.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  24.         }   

  25.         memset(&myctx,0,sizeof(myctx));
  26.         io_set_eventfd(io,efd);
  27.         io_queue_init(1, &myctx);
  28.         if(flg) io_prep_pread(io, fd, buff, iosize, 0);
  29.         else    io_prep_pwrite(io, fd, buff, iosize, 0);
  30.         rc = io_submit(myctx, 1, &io);
  31.         if(rc<0) {
  32.                 close(efd);
  33.                 io_destroy(myctx);
  34.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  35.         }
  36.         if(yield) {
  37.                 rc = yield(efd,0,0);//efd提交給epoll,并yield and resume.
  38.                 if(rc==0) eventfd_read(efd, &finished_aio);
  39.         }
  40.         close(efd);
  41.         num = io_getevents(myctx, 1, 1, &event, NULL);
  42.         if(num>0) {
  43.                 if(event.res2==0) num=event.res;
  44.                 else num=-1;
  45.         }
  46.         io_destroy(myctx);
  47.         return num;
  48. }

  49. int AIO_read(int fd,char *buff,size_t iosize)
  50. {
  51.         return AIO_oper(fd,buff,iosize,0);
  52. }

  53. int AIO_write(int fd,char *buff,size_t iosize)
  54. {
  55.         return AIO_oper(fd,buff,iosize,1);
  56. }

復制代碼

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
9 [報告]
發(fā)表于 2016-08-15 16:21 |只看該作者
本帖最后由 yulihua49 于 2016-08-15 16:22 編輯
cokeboL 發(fā)表于 2016-08-15 14:53
不太清楚你們具體的業(yè)務場景,各種ipc機制和鎖這些,就像過家家,不同的業(yè)務場景和需求,可以有太多中擺法。 ...

發(fā)了個回復怎么丟了?

  1. /*******************************************
  2. * 需要linux 2.6.22 以上版本
  3. * 和libaio 3.107以上版本
  4. * 如果不具備這個條件,在makefile里用SIO_fd.o
  5. * 取代本模塊
  6. *******************************************/

  7. #include <unistd.h>
  8. #include <sys/stat.h>
  9. #include <fcntl.h>
  10. #include <sys/eventfd.h>
  11. #include <libaio.h>

  12. #include <scsrv.h>

  13. static int AIO_oper(int fd,char *buff,size_t iosize,int flg)
  14. {
  15. io_context_t myctx;
  16. int rc,num;
  17. uint64_t finished_aio;
  18. struct iocb _iocb,*io=&_iocb;
  19. struct io_event event;
  20. int     efd = eventfd(0, 0);
  21. T_YIELD yield=get_yield();

  22.         if (efd == -1) {   
  23.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  24.         }   

  25.         memset(&myctx,0,sizeof(myctx));
  26.         io_set_eventfd(io,efd);
  27.         io_queue_init(1, &myctx);
  28.         if(flg) io_prep_pread(io, fd, buff, iosize, 0);
  29.         else    io_prep_pwrite(io, fd, buff, iosize, 0);
  30.         rc = io_submit(myctx, 1, &io);
  31.         if(rc<0) {
  32.                 close(efd);
  33.                 io_destroy(myctx);
  34.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  35.         }
  36.         if(yield) {
  37.                 rc = yield(efd,0,0);//efd提交給epoll,并yield and resume.
  38.                 if(rc==0) eventfd_read(efd, &finished_aio);
  39.         }
  40.         close(efd);
  41.         num = io_getevents(myctx, 1, 1, &event, NULL);
  42.         if(num>0) {
  43.                 if(event.res2==0) num=event.res;
  44.                 else num=-1;
  45.         }
  46.         io_destroy(myctx);
  47.         return num;
  48. }

  49. int AIO_read(int fd,char *buff,size_t iosize)
  50. {
  51.         return AIO_oper(fd,buff,iosize,0);
  52. }

  53. int AIO_write(int fd,char *buff,size_t iosize)
  54. {
  55.         return AIO_oper(fd,buff,iosize,1);
  56. }

復制代碼

論壇徽章:
15
射手座
日期:2014-11-29 19:22:4915-16賽季CBA聯(lián)賽之青島
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16賽季CBA聯(lián)賽之四川
日期:2017-02-07 21:08:572015年亞冠紀念徽章
日期:2015-11-06 12:31:58每日論壇發(fā)貼之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-08-04 06:20:00程序設計版塊每日發(fā)帖之星
日期:2015-07-12 22:20:002015亞冠之浦和紅鉆
日期:2015-07-08 10:10:132015亞冠之大阪鋼巴
日期:2015-06-29 11:21:122015亞冠之廣州恒大
日期:2015-05-22 21:55:412015年亞洲杯之伊朗
日期:2015-04-10 16:28:25
10 [報告]
發(fā)表于 2016-08-15 16:24 |只看該作者
cokeboL 發(fā)表于 2016-08-15 14:53
不太清楚你們具體的業(yè)務場景,各種ipc機制和鎖這些,就像過家家,不同的業(yè)務場景和需求,可以有太多中擺法。 ...

  1. /*******************************************
  2. * 需要linux 2.6.22 以上版本
  3. * 和libaio 3.107以上版本
  4. * 如果不具備這個條件,在makefile里用SIO_fd.o
  5. * 取代本模塊
  6. *******************************************/

  7. #include <unistd.h>
  8. #include <sys/stat.h>
  9. #include <fcntl.h>
  10. #include <sys/eventfd.h>
  11. #include <libaio.h>

  12. #include <scsrv.h>

  13. static int AIO_oper(int fd,char *buff,size_t iosize,int flg)
  14. {
  15. io_context_t myctx;
  16. int rc,num;
  17. uint64_t finished_aio;
  18. struct iocb _iocb,*io=&_iocb;
  19. struct io_event event;
  20. int     efd = eventfd(0, 0);
  21. T_YIELD yield=get_yield();

  22.         if (efd == -1) {   
  23.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  24.         }   

  25.         memset(&myctx,0,sizeof(myctx));
  26.         io_set_eventfd(io,efd);
  27.         io_queue_init(1, &myctx);
  28.         if(flg) io_prep_pread(io, fd, buff, iosize, 0);
  29.         else    io_prep_pwrite(io, fd, buff, iosize, 0);
  30.         rc = io_submit(myctx, 1, &io);
  31.         if(rc<0) {
  32.                 close(efd);
  33.                 io_destroy(myctx);
  34.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  35.         }
  36.         if(yield) {
  37.                 rc = yield(efd,0,0);//efd提交給epoll,并yield and resume.
  38.                 if(rc==0) eventfd_read(efd, &finished_aio);
  39.         }
  40.         close(efd);
  41.         num = io_getevents(myctx, 1, 1, &event, NULL);
  42.         if(num>0) {
  43.                 if(event.res2==0) num=event.res;
  44.                 else num=-1;
  45.         }
  46.         io_destroy(myctx);
  47.         return num;
  48. }

  49. int AIO_read(int fd,char *buff,size_t iosize)
  50. {
  51.         return AIO_oper(fd,buff,iosize,0);
  52. }

  53. int AIO_write(int fd,char *buff,size_t iosize)
  54. {
  55.         return AIO_oper(fd,buff,iosize,1);
  56. }

復制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP