美文网首页
2021-07-19 虾皮面试

2021-07-19 虾皮面试

作者: zecan | 来源:发表于2021-07-20 16:15 被阅读0次

    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 虾皮面试

          本文链接:https://www.haomeiwen.com/subject/vuxrmltx.html