2021-07-19 虾皮面试

1.IO类型 BIO NIO AIO

IO的方式通常分为几种,同步阻塞的BIO,同步非阻塞的NIO,异步非阻塞的AIO
(1)BIO:JDK1.4之前,建立网络连接采用BIO模式,需要现在服务端启动一个ServerSocket,然后再客户端启动Socket来对服务
端进行通信,默认情况下服务端需要对每个请求建立一堆线程等待请求,而在客户端发送请求后,先咨询服务端是否有线程响
应,如果没有则会一直等待,如果有的话,客户端会等待线程结束后才继续执行。
(2)NIO:继续实践驱动思想来完成。NIO基于Reactor模式来实现的,相当于一个线程处理大量的客户端请求,通过一个线程轮
询大量的channel,每次就获取一批有事件的channel,然后对每个请求启动一个线程处理。
非阻塞,selector一个线程不停轮询channel,所有的客户端请求都不会阻塞,直接就会进来。
相对于bio的优化:一个客户端并不是时时刻刻都有数据进行交互,没必要死耗着一个线程不放,所以客户端选择让线程歇一歇,
只有客户端有相应的操作的时候才发起通知,创建一个线程来处理请求。
(3)AIO:异步非阻塞IO,基于Proactor模型实现。每个连接发送过来的请求,都会绑定到一个buffer,然后通知操作系统去完成
异步的读,这个时间你就可以去做其他的事情,等到操作系统完成读之后,就会调用你的接口,给你操作系统异步读完的数据。
这个时候你就可以拿到数据进行处理,将数据往回写,在往回写的过程,同样是给操作系统一个buffer,让操作系统去完成写,写
完了来通知你。这两个过程都有buffer存在,数据是通过buffer来完成读写的。
这里面的主要区别在于将数据写入到缓冲区后,就不去管它,剩下的交给操作系统去完成。操作系统写回数据也是一样,写到
buffer里面,写完后通知客户端来警醒读取数据。

基本概念:
同步和异步:同步和异步是针对应用程序和内核的交互而言的。
同步指的是用户进程触发IO操作,等待或轮询的去查看IO操作是否就绪;
异步指的是用户进程触发IO操作以后便开始做自己的事情,而当IO操作已经完成的时候就会得到IO完成的通知。

阻塞和非阻塞:阻塞和非阻塞是针对进程在访问数据的时候,根据IO的就绪状态来采取不同的方式,说白了是一种读取或写去操
作方法的实现方式。
阻塞方式下,读取或写入函数将会一直等待;
非阻塞方式下,读取或写入方法会立即放回一个状态值。

你可能感兴趣的:(2021-07-19 虾皮面试)