非阻塞IO(NIO)
一、前言
1.1、阻塞IO,BIO
BIO(Blocking I/O)
也称作同步阻塞IO。
1.2、非阻塞IO,NIO
NIO(Non-blocking I/O)
也称作同步非阻塞IO;
现在常用的NIO,是NIO+IO多路复用的结合体,epoll 还是会阻塞线程,不是真正的非阻塞IO。
1.3、异步IO,AIO
AIO(Asynchronous I/O)
二、同步/异步 和 阻塞/非阻塞
2.1 概念
- 同步
调用方发起一个功能调用时,在没有得到功能的结果之前,该调用不会返回。也就是调用方会等待被调用方返回功能的结果。 - 异步
调用方发起一个功能调用时,没有得到功能的结果立即返回,后续被调用方再通过回调等手段,把功能的结果通知调用方。也就调用方立即得到返回,但是返回中不包含功能结果。
Linux 的 AIO 中,异步的结果是通过内核的回调拿到的
- 阻塞
线程发起一个调用时,在调用返回之前,线程会被阻塞,在这个状态下会交出当前CPU的使用权限而暂停。也就是调用方会等待调用结果,调用阻塞了调用方的线程,线程不在运行处理中。 - 非阻塞
线程发起一个调用时,调用会立即返回,避免线程被阻塞。但是返回结果只是被调用方当前状态的值,实际使用时,调用方需要轮询,走到返回结果符合预期(直到数据准备好)