在Linux中进程空间和内核空间是分开的,系统调用是在Kernel中,IO 数据会先复制到进程空间,这样进程才能访问。
所以Linux I/O分为2个步骤:等待数据和复制数据
1. 阻塞I/O(Blocking IO)
socket的默认方式。
请求IO进程(recvfrom)会一直处于阻塞状态,这种效率极低。
2. 非阻塞IO
recvfrom不会阻塞,通过不断查询Kernel的状态获取信息。
3. IO复用(Multiplexing)
Kern
在Linux中进程空间和内核空间是分开的,系统调用是在Kernel中,IO 数据会先复制到进程空间,这样进程才能访问。
所以Linux I/O分为2个步骤:等待数据和复制数据
socket的默认方式。
请求IO进程(recvfrom)会一直处于阻塞状态,这种效率极低。
recvfrom不会阻塞,通过不断查询Kernel的状态获取信息。
Kern