ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
# 网络IO - [1. 常见IO方式](#1_IO_3) - [1.1 BIO(同步阻塞IO)](#11_BIOIO_5) - [1.2 NIO(同步非阻塞IO)](#12_NIOIO_7) - [1.3 多路复用IO](#13_IO_9) - [1.4 信号驱动IO](#14_IO_11) - [1.5 异步IO](#15_IO_13) ## 1. 常见IO方式 ### 1.1 BIO(同步阻塞IO) 阻塞整个步骤,如果连接少,他的延迟是最低的,因为一个线程只处理一个连接,适用于少连接且延迟低的场景,比如说数据库连接。 ### 1.2 NIO(同步非阻塞IO) 阻塞业务处理但不阻塞数据接收,适用于高并发且处理简单的场景,比如聊天软件。 ### 1.3 多路复用IO 他的两个步骤处理是分开的,也就是说,一个连接可能他的数据接收是线程a完成的,数据处理是线程b完成的,他比BIO能处理更多请求,但是比不上NIO,但是他的处理性能又比BIO更差,因为一个连接他需要两次system call,而BIO只需要一次,所以这种IO模型应用的不多。 ### 1.4 信号驱动IO 这种IO模型主要用在嵌入式开发 ### 1.5 异步IO 他的数据请求和数据处理都是异步的,数据请求一次返回一次,适用于长连接的业务场景。