BIO,NIO,AIO分别是什么?他们有什么区别?

1、BIO

概念:

        BIO是一种同步阻塞I/O模式,服务实现模式为一个连接对应一个线程,即客户端发送一个连接,服务端要有一个线程来处理。

存在的问题:

        一旦有高并发的大量请求,就会有如下问题: 1)线程不够用,就算使用了线程池复用线程也无济于事;2)阻塞I/O模式下,会有大量的线程被阻塞,一直在等待数据,这个时候的线程被挂起,只能干等,CPU利用率很低,换句话说,系统的吞吐量差;3)如果网络I/O堵塞或者有网络抖动或者网络故障等,线程的阻塞时间可能很长,整个系统也变的不可靠;4)服务器线程太多,压力太大,导致服务器宕机。

2、NIO

概念

        NIO是一种同步非阻塞I/O模式,服务实现模式是一个线程可以处理多个连接,即客户端发送的连接都会注册到多路复用器上,然后进行轮询连接,有I/O请求就处理。

        处理过程如下:

        1)一个客户端会对应一个channel,然后多路复用器selector会轮询channel;

        2)然后当有请求过来的时候,selector才会去创建工作线程与buffer;

        3)工作线程会通过buffer从channel中读取请求并进行处理,此时客户端可以进行其他操作,所以是非阻塞的;

        4)然后处理完成后再通过buffer将数据返回给channel,客户端会当请求读写完成后会释放这个线程。

3、AIO

        AIO 也就是 NIO 2。在 Java 7 中引⼊了 NIO 的改进版 NIO 2,它是异步非阻塞的 IO 模型。异步 IO 是基于事件和回调机制实现的,也就是应⽤操作之后会直接返回,不会堵塞在那⾥,当后台处理完成,操作系统会通知相应的线程进⾏后续的操作。AIO 是异步 IO 的缩写,虽然 NIO 在⽹络操作中,提供了⾮阻塞的方法,但是 NIO 的 IO 行为还是同步的。对于 NIO 来说,我们的业务线程是在 IO 操作准备好时,得到通知,接着就由这个线程自进行 IO 操作,IO 操作本身是同步的,但AIO是异步非阻塞的,也就是说当有请求过来的时候,工作线程会通知操作系统异步去读,然后就可以去干别的事,等操作系统完成数据读取之后,就会回调接口,给你操作系统异步读完的数据。

你可能感兴趣的:(Java,java)