1.1IO基础入门
java1.4之前的版本中,对IO的支持并不完善,主要问题如下:
- 没有数据缓冲区,IO性能存在问题
- 没有C/C++中Channel的概念,只有输入输出流
- 只支持同步阻塞式IO(BIO),经常导致通信线程被长时间阻塞
- 支持的字符集有限,硬件可移植性不好
1.1.1 Linux网络IO模型简介
Unix提供了5种IO模型:
- 阻塞IO模型
- 非阻塞IO模型
- IO复用模型
- 信号驱动IO模型
- 异步IO模型
由于对于java程序员来说,大多数时候用不到网络编程的底层细节,linux网络模型这块暂不做深入研究,等以后用到了再做研究。
1.1.2 IO多路复用技术
在IO编程中,当一个服务端线程同时处理多个客户端接入请求时,可以利用多线程或者IO多路复用技术。IO多路复用最大的优势就是系统开销小,不需要再为每一个连接都创建一个处理线程。
1.2 JAVA的IO演进
1)jdk1.0到jdk1.3,只提供BIO
2)jdk1.4新增java.nio包,提供了NIO开发的API和类库,主要类和接口:
- 进行异步I/O操作的缓冲区ByteBuffer等
- 进行异步I/O操作的管道Pipe
- 进行各种I/O(异步或同步)的Channel,包括ServerSocketChannel和SocketChannel
- 多种字符集的编码能力和解码能力
- 实现非阻塞I/O操作的多路复用器selector
- 基于流行的Perl实现的正则表达式类库
- 文件通道FileChannel
3)jdk1.7将原来的NIO类库升级,主要改进三个方面:
- 提供能够批量获取文件属性的API,这些API具有与平台无关性,不与特性文件系统相耦合
- 提供AIO功能,支持基于文件的异步I/O操作和针对网络套接字的异步操作
- 完成通道功能,包括对配置和多播数据报的支持