在说明这些IO之前,要了解程序运行的一些东西。程序的运行分用户态和内核态。用户态,就是应用程序层的数据状态,内核态就是内核数据状态。应用程序是基于内核(操作系统)运行的。
一个IO请求由两部分组成:
1、内核是否准备好数据(读操作)或者内核是否准备好接收数据(写操作),成为准备阶段。
2、把数据从内核内存copy到应用程序内存(读操作)或者从应用程序内存copy到内核内存(写操作),成为复制阶段。
第1步是内核与设备的交互(例如网卡、磁盘等等),第2步是内核与应用程序交互。
当进行一个读操作的时候,数据从设备copy到内核内存,然后从内核内存copy到应用程序内存。
阻塞IO:就是一个IO操作请求,准备阶段和复制阶段都会阻塞应用程序,直到操作完全完成。
非阻塞IO:就是一个IO操作请求,先判断准备阶段是否完成,如果未完成立刻返回,否则,进入复制阶段,在这个时候复制阶段是阻塞的,直到操作完全完成。
同步IO:同步IO包含了阻塞IO与非阻塞IO,所以这里的同步指的是IO操作请求的完全完成。无论是阻塞还是非阻塞IO在复制阶段应用程序都是要阻塞的。程序可以通过while循环轮询内核。
异步IO:就是一个IO操作请求后就立刻返回,直到准备阶段与复制阶段都完成了,内核才通知应用程序。这时候应用程序可以直接操作用户内存了。