两种高效的事件处理模式
来源:互联网 发布:卡通艺术字软件下载 编辑:程序博客网 时间:2024/06/15 19:56
服务器程序通常需要处理三类事件:I/O事件、信号及定时事件。
同步I/O模型通常用于实现Reactor模式,异步I/O模型则用于实现Proactor模式。
Reactor模式
Reactor是这样一种模式,它要求主线程(I/O处理单元)只负责监听文件描述符上是否有事件发生,有的话就立即将该事件通知工作线程(逻辑单元)。除此之外,主线程不做任何其他实质性的工作。读写数据,接受新的连接,以及处理客户请求均在工作线程中完成。
Proactor模式
与Reactor模式不同,Proactor模式将所有I/O操作都交给主线程和内核来处理,工作线程仅仅负责业务逻辑。
模拟Proactor模式
主线程执行数据读写操作,读写完成之后,主线程向工作线程通知这一“完成事件”。那么从工作线程的角度来看,它们就直接获得了数据读写的结果,接下来要做的只是对读写的结果进行逻辑处理。
0 0
- 两种高效的事件处理模式
- 两种高效的事件处理模式和并发模式
- 两种高效的事件处理模式 reacotr模式和proactor模式
- reactor/proactor两种高效的事件处理模式和并发模式
- 两种高效的事件处理模型:Reactor模式和Proactor模式
- Linux服务器--服务器模型,I/O模型,两种高效的事件处理模式
- 三.两种高效事件处理模型
- 高效的事件处理模式和高效的并发模式
- 两种高效的并发模式
- 四.两种高效的并发模式
- 两种高效的并发模式
- 两种高效的并发模式
- 服务器两种高效的并发模式
- Reactor模式,两种高效的并发模式
- JS处理事件的两种方式
- 表单事件的两种处理方法
- Android事件处理的两种模型
- Android事件处理的两种模型
- WOai wojiao
- 鸡啄米vc++2010系列38(文档、视图和框架:概述)
- wireshark抓包dhcp
- Displaying Bitmaps Efficiently
- request中url
- 两种高效的事件处理模式
- 倒序输出你输入的正整数
- C++学习 boost学习之-scoped_array
- HTTP和HTTPS详解
- 给TEXTVIEW添加背景吧
- Windows学习篇之---Skype掉线问题
- linux集群性能测试
- 微信公众号开发实现原理
- 苹果电脑锁屏忘记密码