1.I/O介绍
按照百度百科上对IO的定义来说,计算机领域的I/O指的是输入/输出流,输入输出I/O流可以看成对字节或者包装后的字节的读取就是拿出来放进去双路切换;实现联动控制系统的弱电线路与被控设备的强电线路之间的转接、隔离,以防止强电窜入系统,保障系统的安全。
Unix提供了5种I/O模型:
- 阻塞I/O模型(blocking I/O):缺省情况下,所有操作都是阻塞的。
- 非阻塞I/O模型(noblocking I/O):定时轮训是否有数据到来,无数据返回固定错误码,有数据则进行数据复制
- I/O多路复用模型(I/O multiplexing):select/poll顺序扫描N个fd检测是否有数据到来。epoll基于事件驱动方式扫描fd,检测是否有数据到来。
- 信号驱动I/O模型(signal blocking I/O):系统生成SIGIO信号,通过信号回调通知程序数据到来。
- 异步I/O模型(asynchronous I/O):与信号驱动模型的区别在于异步I/O内核通知进程I/O数据操作已经完成;信号驱动则通知数据已经到达。
2.Java的I/O演进之路
- JDK1.0到1.3之间,java提供的IO操作库都是阻塞I/O;
- JDK1.4中开始提供java.nio包,通过了很多进行异步I/O开发的API和类库,实现非阻塞I/O操作的多路复用器selector;
- JDK1.7中将之前的NIO库进行了升级,被称为NIO2.0,开始支持批量获取文件属性,支持基于文件的异步I/O。