天天看点

IO NIO AIO 同步 异步 阻塞 非阻塞

传统javaIO 是同步阻塞IO,在同一个线程内,必须等到阻塞线程返回才会继续处理

NIO 是同步非阻塞IO,还是在同一个线程内处理,只不过是设置为非阻塞,同时selctor 会不断查询channel 状态,状态的变更同一处理线程会进行不同的处理

AIO 是异步非阻塞IO

阻塞与非阻塞 指的是对内存而言,例如内存读取文件内容,读取网卡内容

异步与非异步指的是针对是否一个线程处理进行处理还是多线程协作

备注:一般大家说 NIO 是非阻塞的,指的是网络编程中客户端与服务端连接交换数据的过程是非阻塞的。普通的文件读写依然是阻塞的,和 IO 是一样的,这一点可能很多初学者会懵,包括我当时也总想不通为什么说 NIO 的文件读写是非阻塞的,明明就是阻塞的。

继续阅读