Linux网络编程---I/O多路复用之select

1.I/O多路复用(IO multiplexing)

我们之前讲了I/O多路复用和其他I/O的区别,在这里,我们再具体讨论下I/O多路复用是怎么工作?
I/O 多路复用技术就是为了解决进程或线程阻塞到某个 I/O 系统调用而出现的技术,使进程不阻塞于某个特定的 I/O 系统调用。

select(),poll(),epoll()都是I/O多路复用的机制。I/O多路复用通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就绪或者写就绪,就是这个文件描述符进行读写操作之前),能够通知程序进行相应的读写操作。 但select(),poll(),epoll()本质上都是同步I/O,因为他们都需要用户进程在读写事件就绪后自己负责进行读写,也就是说这个读写过程是阻塞的,而异步I/O则无需自己负责进行读写,异步I/O的实现内核会负责把数据从内核拷贝到用户空间。

与多线程和多进程相比,I/O 多路复用的最大优势是系统开销小,系统不需要建立新的进程或者线程,从而也就不必维护这些线程和进程。

具体来说就是单个进程(process)就可以同时处理多个网络连接的IO。它的基本原理就是select/epoll这个函数(function)会不断的轮询所负责的所有socket,当某个socket有数据到达了,就通知用户进程。它的流程如图:
Linux网络编程---I/O多路复用之select_第1张图片

如果还不清楚,我们接下来一个一个来理解。

I/O多路复用—select

select系统调⽤是⽤来让我们的程序监视多个⽂件描述符的状态变化的;
程序会停在select这⾥等待,直到被监视的⽂件描述符有⼀个或多个发⽣了状态改变

1. 所需头文件

#include 
#include 
#include 
#include 

int select(int nfds

你可能感兴趣的:(Linux,Linux网络编程,select,同步,异步)