epoll在多线程并发下需要用到EPOLLONESHOT防止多个线程处理同一个事件,但是这样就变成无论ET还是LT都需要循环读写确保这个线程单独处理完这个事件,而且每次处理完事件都需要重置events,这样ET和LT的优势好像都没了,是不是基本没什么不同了?或者说还有其他更好的多线程处理事件的方法?
epoll在多线程并发下需要用到EPOLLONESHOT防止多个线程处理同一个事件,但是这样就变成无论ET还是LT都需要循环读写确保这个线程单独处理完这个事件,而且每次处理完事件都需要重置events,这样ET和LT的优势好像都没了,是不是基本没什么不同了?或者说还有其他更好的多线程处理事件的方法?
15 回答8.4k 阅读
3 回答2k 阅读✓ 已解决
4 回答4.4k 阅读✓ 已解决
4 回答4k 阅读
2 回答3.9k 阅读✓ 已解决
2 回答3.2k 阅读✓ 已解决
1 回答3k 阅读✓ 已解决
第一个问题目前我也不清楚。
第二个问题你可以看下muduo网络库,采用每个线程开一个io loop,同一个fd上的事件保证只由一个线程处理。专门用一个线程accept连接,然后分发给这些io loop线程。