事件驱动模型是一种响应事件模型,事件驱动就是在持续事务管理的过程中,由当前时间点上出现的事件引发的调动可用资源执行相关任务,解决不断出现的问题,防止事务堆积的一种策略。
事件驱动程序设计:是一种程序设计方式
事件驱动模型的组成:事件收集器,事件发送器,事件处理器
事件收集器:收集所有的时间
事件发送器:将收集器收集到的时间分发到目标对象中,目标对象就是事件处理器所处的位置
事件处理器负责事件的响应工作,往往要到实现阶段才完全确定
目标对象中的事件处理器的实现方法:
事件发送器每传递过来一个请求,目标对象
1、创建一个新的进程
2、创建一个新的线程
3、将其放入一个待处理事件的列表,使用非阻塞I/O方式
调用“事件处理器”来处理该请求
事件驱动处理库(多路IO复用方法)
select模型、poll模型、epoll模型
select库:创建所关注事件的描述符集合,创建三类事件描述符集合(读事件,写事件,异常发生事件);调用底层提供的select()函数,等待事件发生;轮询所有事件描述符集合中的每一个事件描述符。检查是否有相应的时间发生,如果有,就进行处理。
poll库:只需要创建一个集合,在每个描述符对应的结构上分别设置读事件、写事件、或者异常事件,最后轮询的时候,可以同时检查这三个事件是否发生
epoll库:把描述符列表的管理交由内核负责,一旦有某种事件发生,内核把发生事件的描述符列表通知给进程。首先,epoll库就开始等待内核筒子事件发生了,某一事件发生后,内核将发生时间的额描述符列表上报给epoll库。得到事件列表的epoll库就可以进行事件处理了。