IO模型
IO:即输入(Input)和输出(Output),以内存为目标,数据进内存叫In,数据出内存叫Out
五种IO模型
同步阻塞 BIO
阻塞IO就是当应用发起读取数据申请时,在内核数据没有准备好之前,应用会一直处于等待数据状态,直到内核把数据准备好了交给应用才结束。
当调用线程发起 read
系统调用时,如果此时内核数据还没有 Ready,调用线程会阻塞住,等待内核 Buffer 的数据。内核数据准备就绪之后,会将内核态 Buffer 的数据复制到用户态 Buffer 中,这个过程中调用线程仍然是阻塞的,直到数据复制完成>
异步非阻塞 NIO (Non-Blocking IO)
非阻塞IO就是当应用发起读取数据申请时,如果内核数据没有准备好会即刻告诉应用,不会让在这里等待。
数据准备阶段。此时用户线程发起 read 系统调用,此时内核会立即返回一个错误,告诉用户态数据还没有 Read,然后用户线程不停地发起请求,询问内核当前数据的状态。
数据复制阶段。此时用户线程还在不断的