两种高效的事件处理模式
2015-05-21 11:04
253 查看
服务器程序通常需要处理三类事件:I/O事件、信号及定时事件。
同步I/O模型通常用于实现Reactor模式,异步I/O模型则用于实现Proactor模式。
Reactor模式
Reactor是这样一种模式,它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将该事件通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作。读写数据,接受新的连接,以及处理客户请求均在工作线程中完成。
Proactor模式
与Reactor模式不同,Proactor模式将所有I/O操作都交给主线程和内核来处理,工作线程仅仅负责业务逻辑。
模拟Proactor模式
主线程执行数据读写操作,读写完成之后,主线程向工作线程通知这一“完成事件”。那么从工作线程的角度来看,它们就直接获得了数据读写的结果,接下来要做的只是对读写的结果进行逻辑处理。
同步I/O模型通常用于实现Reactor模式,异步I/O模型则用于实现Proactor模式。
Reactor模式
Reactor是这样一种模式,它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将该事件通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作。读写数据,接受新的连接,以及处理客户请求均在工作线程中完成。
Proactor模式
与Reactor模式不同,Proactor模式将所有I/O操作都交给主线程和内核来处理,工作线程仅仅负责业务逻辑。
模拟Proactor模式
主线程执行数据读写操作,读写完成之后,主线程向工作线程通知这一“完成事件”。那么从工作线程的角度来看,它们就直接获得了数据读写的结果,接下来要做的只是对读写的结果进行逻辑处理。
相关文章推荐
- 两种高效的事件处理模型:Reactor模式和Proactor模式
- 服务器程序框架之3.两种高效的事件处理模式
- 两种高效的事件处理模式
- 两种高效的事件处理模型:Reactor模式和Proactor模式
- Linux服务器--服务器模型,I/O模型,两种高效的事件处理模式
- 两种高效的事件处理模式和并发模式
- reactor&&proactor 两种高效的事件处理模式
- reactor/proactor两种高效的事件处理模式和并发模式
- 两种高效的事件处理模式 reacotr模式和proactor模式
- 两种高效的事件处理模式
- 服务器两种高效的事件处理模式
- 高效的事件处理模式和高效的并发模式
- linux服务器编程之高效事件处理模式
- 服务端处理事件的两种模式--Reactor和Proactor
- 事件处理之一:两种方式:监听器与回调 分类: H1_ANDROID 2013-10-31 10:26 3250人阅读 评论(0) 收藏
- python文件处理,b模式的读写,rb, wb,编码的两种方式
- Esper事件处理引擎_14_EPL 语法_7_Patterns_1_模式匹配
- 高效处理Java异常的两种方法
- Redis 与 数据库处理数据的两种模式
- 全屏模式下处理Silverlight控件的两种方式