I/O模型
有五种I/O模型:
- 阻塞型I/O:blocking IO
- 非阻塞型I/O:nonblocking IO
- I/O复用:IO multiplexing
- 信号驱动I/O:signal driven IO
- 异步I/O:asynchronous IO
对于一个network IO (以read举例),它会涉及到两个系统对象:一个是调用这个IO的进程,另一个就是系统内核(kernel)。当一个read操作发生时,它会经历两个阶段:
阶段1: 等待数据准备 (Waiting for the data to be ready)
阶段2: 将数据从内核拷贝到进程中 (Copying the data from the kernel to the process)
阻塞型I/O
阻塞型IO就是,数据的读入和写出都在一个线程内,需要等待其完成。
当在使用阻塞IO的时候,应用程序会被无情的挂起,等待内核完成操作,因为此时的内核可能将CPU时间切换到了其它需要的进程中,在我们的应用程序看来感觉被卡主(阻塞)了。
采用 BIO 通信模型 的服务端,通常由一个独立的 Acceptor 线程负责监听客户端的连接。我们一般通过在while(