阻塞与非阻塞
阻塞概念
阻塞就是只要没有检测到文件描述符发生变化,即有客户端连接或者有数据可读,进程就一直阻塞,直到内核TCP缓冲区有数据可读。
一般来说,传输层以下(包含传输层)为内核区,传输层以上为用户区。
非阻塞概念
非阻塞忙轮询,就是只要检测到没有文件描述符发生变化就一直循环检测,直到有数据可读,进行读取数据。
在select,poll,epoll三种io复用模型中,均可以通过设置超时时间来决定是阻塞还是非阻塞,即超时时间设置为NULL代表永久阻塞,为0代表不阻塞,大于0代表阻塞的具体时间
同步与非同步
同步概念
同步就是当检测到有事件发生时,需要用户自己去读取数据,数据读取完了才能进行下一步操作。
异步概念
异步就是当检测到有事件发生时,由内核帮忙完成数据的读写,只需要IO操作完成的通知。
在select,poll,epoll三种io复用模型中,数据到来时均需要自己去读写数据,因此均属于同步。
epoll的ET模式和LT模式
ET模式
ET模式即为边缘触发模式, 只要epoll_wait检测到有事件发生,通知应用程序立即处理,此后epoll_wait不再检测此事件,因此ET模式降低了同一个事件被epoll再次触发的次数,因此效率高。需要不断循环读取数据,直到读取到的结果<0且出现的错误号为 egain或者ewouldblock时代表数据读取完毕,完毕文件描述符,退出循环。
LT模式
LT模式即为水平触发模式,是epoll的默认操作模式,只要检测到有事件发生,就不断通知应用程序,直到事件被处理。