什么叫IO?
    IO是Input/Output,描述了计算机和外部设备通信的过程。

    • 由于用户进程对外部设备的管理需要通过系统调用来进入内核Kernel空间。我们应用程序发起了IO的调用,IO的执行是由操作系统的Kernel完成的
    • 当应用程序发起 I/O 调用后,会经历两个步骤:、
      1. 内核等待 I/O 设备准备好数据
      2. 内核将数据从内核空间拷贝到用户空间。
    • Java中三种IO模型
      • BIO 属于同步阻塞 IO 模型 。同步阻塞 IO 模型中,应用程序发起 read 调用后,会一直阻塞,直到在内核把数据拷贝到用户空间。IO模型 - 图1
      • 非阻塞IO模型(Non-blocking/New IO) / 同步非阻塞模型IO模型 - 图2
        • 同步非阻塞 IO 模型中,应用程序会一直发起 read 调用,等待数据从内核空间拷贝到用户空间的这段时间里,线程依然是阻塞的,直到在内核把数据拷贝到用户空间。相比于同步阻塞 IO 模型,同步非阻塞 IO 模型确实有了很大改进。通过轮询操作,避免了一直阻塞。但是,这种 IO 模型同样存在问题:应用程序不断进行 I/O 系统调用轮询数据是否已经准备好的过程是十分消耗 CPU 资源的。
    • IO多路复用模型
      • IO 多路复用模型中,线程首先发起 select 调用,询问内核数据是否准备就绪,等内核把数据准备好了,用户线程再发起 read 调用。read 调用的过程(数据从内核空间->用户空间)还是阻塞的。IO模型 - 图3IO 多路复用模型,通过减少无效的系统调用,减少了对 CPU 资源的消耗。(比如当由10000个网络连接请求,但是只有1个数据传送请求的时候,selector通过select()/epoll(), 把对应的channel装进rdlist中,再进行read)
    • 异步阻塞模型AIO(Asynchronous I/O)
      • IO模型 - 图4