IO、NIO

2018-04-03  本文已影响87人  battle_

IO、NIO

Java NIO和IO之间第一个最大的区别是,IO是面向流的,NIO是面向缓冲区的。 Java IO面向流意味着每次从流中读一个或多个字节,直至读取所有字节,它们没有被缓存在任何地方。此外,它不能前后移动流中的数据。如果需要前后移动从流中读取的数据,需要先将它缓存到一个缓冲区。 Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。而且,需确保当更多的数据读入缓冲区时,不要覆盖缓冲区里尚未处理的数据。

IO流包括字节流和字符流:

字节流:对应抽象类为InputStream(输入流)和 OutputStream(输出流)。 FileInputStream、FileOutputStream

字符流:对应抽象类为Reader(输入流)和Writer(输出流)。BufferedReader、InputStreamReader、 StringReader

IO

装饰器模式

磁盘操作

保存文件的基本信息,文件路径等,不保存文件内容

字节操作

子类装饰器提供额外的功能:FileInputStream,StringBufferInputStream,ByteArrayInputStream,FilterInputStream(PushbackInputStream,BufferedInputStream,DataInputStream,LineNumberInputStream)

BufferedInputStream bis = new BufferedInputStream(new FileInputStream(new File("path")))
byte[] buf = new  byte[20 * 1024];
int bytes = 0;
while((bytes = in.read(buf, 0, buf.length)) != -1){
}

字符操作

一般情况下操作的都是字符流

inputStreamReader支持从文本文件的字节流转换为字符流-解码

byte[] bytes = str.getBytes(encoding);//编码
String str = new String(bytes, encoding);//解码

outputSreamWriter支持字符流编码转换为文本文件字节流-编码

对象操作

序列化,对象需要实现serializable接口,transiend修饰的变量不进行序列化

ObjectOutputStream.writObject()//序列化
ObjectInputStream.readObject()//反序列化

网络操作

NIO

高速的面向块的IO
一次处理数据块,比按流处理要快,但是面向块的IO缺少一些面向流IO所具有的优雅性和简单性

通道Channel是对原IO包中的流的模拟,可以通过他读取和写入数据。
通道与流的区别是,流操作都是单向的如InputStream/OutputStream,而通道是双向的,一个Channel就可完成读写两个操作

- FileChannel 从文件中读写数据
- DatagramChannel 通过UDP读写网络数据
- SocketChannel 通过TCP读写网络数据
- ServerSocketChannel 监听新进来的TCP链接,对每一个新的连接都会创建一个SocketChannel

通道在读写数据之前,都需要将目标对象放入到缓冲区中,缓冲区实质是一个数组,提供了对数据的结构化访问,还可以跟踪系统的读写进程

- ByteBuffer
- CharBuffer
- ShortBuffer
- IntBuffer
- LongBuffer
- FloatBuffer
- DoubleBuffer
上一篇下一篇

猜你喜欢

热点阅读