1、阻塞IO模型
最基础的IO模型,在读写数据过程中会发生阻塞现象。
在等待IO完成的过程中,用户线程会处于阻塞状态,让出CPU使用权。
IO完成以后,用户线程解除阻塞。
2、非阻塞IO模型
用户线程发起一个read操作,不需要等待,而是马上得到了一个结果,如果结果是error时,它就知道数据还没准备好,于是再次发送read操作。
在读写数据过程中不会发生阻塞现象。
在等待IO完成的过程中,用户线程会不断地询问IO是否完成。
非阻塞IO不会让出CPU使用权,一直占用CPU
3、多路复用IO模型
在多路复用IO模型中,会有一个线程不断去轮询多个socket的状态,只有当socket真正有读写时间时候,才真正调用实际的IO读写操作。
只需要使用一个线程就可以管理多个socket连接。而且只有在真的有socket读写事件的时候,才会使用IO资源,降低了资源的占用。
4、信号驱动IO模型
在信号驱动IO模型中,当用户线程发起一个IO请求操作,会给对应的 socket 注册一个信号函数,然后用户线程会继续执行,当内核数据就绪时会发送一个信号给用户线程,用户线程接收到信号之后,便在信号函数中调用 IO 读写操作来进行实际的 IO 请求操作。
5、异步IO模型
在异步 IO 模型中,当用户线程发起 read 操作之后,立刻就可以开始去做其它的事。
整个过程中,线程只需要发起一个请求即可,内核系统完成IO的时候,直接使用数据。