聊聊BIO、NIO、AIO分别都是啥?有什么区别?

BIO的网络通信原理

BIO的特点就是每次一个客户端接入,都要在服务端创建一个线程来服务于这个客户端,所以如果有很多个客户端,就会对应成千上万个服务端线程,这会导致服务端负载过高,甚至卡死。
聊聊BIO、NIO、AIO分别都是啥?有什么区别?_第1张图片

NIO的网络通信原理

1.一个客户端会对应一个channel,然后多路复用器selector会轮询channel
2. 然后当有请求过来的时候,selector才会去创建工作线程与buffer,
3. 工作线程会通过buffer从channel中读取请求并进行处理
4. 然后处理完成后再通过buffer将数据返回给channel,当请求读写完成后会释放这个线程
聊聊BIO、NIO、AIO分别都是啥?有什么区别?_第2张图片

AIO通信原理

与NIO是类似的,但是它是异步非阻塞的,也就是说当有请求过来的时候,工作线程会通知操作系统异步去读,然后就可以去干别的事,等操作系统完成数据读取之后,就会回调接口,给你操作系统异步读完的数据。

三者之间的区别:
BIO是同步阻塞,NIO是同步非阻塞,AIO是异步非阻塞,而这些都是针对文件IO的读写操作,这里的阻塞指的是线程发起读写请求之后,是不是阻塞住的,是不是可以干别的事。而异步与同步其实是说操作系统之间,同步就是还得主动去轮询操作系统,异步就是操作系统反过来通知你。

你可能感兴趣的:(Java基础,网络,nio,netty,java,多线程)