BIO &NIO &AIO简单入门
java的I/O是逐步演进的从原始的BIO到NIO以及1.7以后的NIO 2.0。本街会通过几个示例介绍不同的I/O。
一、JDK的BIO
传统的BIO模型是一个C/S结构,Serversocket负责绑定IP地址,启动监听端口;Socket负责发起连接操作。
时间服务器TimeServer
最简单的IO模型,服务端阻塞式处理连接
遇到的问题
serverHandler 使用 bufferReader获取socket的输入流,预期结果是循环读取完所有的输入,然后进行回应。实际上只会卡死在readline()
原因
不能直接从流中读取
死循环读会不会像读文件一样主动返回EOF,只能卡死
二、伪异步I/O(线程池)
为了解决简单BIO即来即联,对线程数量无限制的缺陷,可以通过线程池的方式进行改进。
Runtime.getRuntime().availableProcessors()
链接Runtime.getRuntime()可以获取Jvm的运行实例,availableProcessors可以获取可获得线程数,与cpu的核数有关系。
code
ArrayBlockQueue
有界队列
弊端分析
不通socket处理流的速度不同,BIO的问题在于,当某个线程获取I/O后处理缓慢,其余线程只能加入队列中等待。
- 服务端处理缓慢
三、NIO
NIO是异步I/O,与socket和serverSocket对应,NIO提供了SocketChannel
和ServerSocketChannel
。新类支持阻塞和非阻塞式。
NIO类库介绍
1. 缓冲区buffer
NIO加入缓冲区Buffer对象,与旧库的区别是,在面向流的I/O时,可以把数据直接写入Stream对象中。
NIO的库中所有对象的读写都是用缓冲区处理的:读数据是从缓冲区读,写数据是写入缓冲区。
缓冲区通常是一个数组(ByteBuffer),除此之外还定义了一些其他的操作。
- ByteBuffer 字节缓冲区 最常用
- CharBuffer 字符缓冲区
- ShortBuffer 短型缓冲区
- IntBuffer 整型缓冲区
- LongBuffer
- FloatBuffer
- DoubleBuffer
2. channel 通道
可以进行读写,与Stream的区别是:channel是全双工
双向的,一个流只能是(inputStream或outputStream的子类)单向移动,channel既可以读也可以写。
–类继承结构
自定向下看,前三次都是channel的接口用来定义它的功能。后面是一些具体的功能类