IO、NIO
Java NIO和IO之间第一个最大的区别是,IO是面向流的,NIO是面向缓冲区的。 Java IO面向流意味着每次从流中读一个或多个字节,直至读取所有字节,它们没有被缓存在任何地方。此外,它不能前后移动流中的数据。如果需要前后移动从流中读取的数据,需要先将它缓存到一个缓冲区。 Java NIO的缓冲导向方法略有不同。数据读取到一个它稍后处理的缓冲区,需要时可在缓冲区中前后移动。这就增加了处理过程中的灵活性。但是,还需要检查是否该缓冲区中包含所有您需要处理的数据。而且,需确保当更多的数据读入缓冲区时,不要覆盖缓冲区里尚未处理的数据。
IO流包括字节流和字符流:
字节流:对应抽象类为InputStream(输入流)和 OutputStream(输出流)。 FileInputStream、FileOutputStream
字符流:对应抽象类为Reader(输入流)和Writer(输出流)。BufferedReader、InputStreamReader、 StringReader
IO
装饰器模式
磁盘操作
- File
保存文件的基本信息,文件路径等,不保存文件内容
字节操作
- InputStream
子类装饰器提供额外的功能: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){
}
-
OutputStream
bytes
字符操作
一般情况下操作的都是字符流
- Reader
inputStreamReader支持从文本文件的字节流转换为字符流-解码
byte[] bytes = str.getBytes(encoding);//编码
String str = new String(bytes, encoding);//解码
- Writer
outputSreamWriter支持字符流编码转换为文本文件字节流-编码
对象操作
- Serializable
序列化,对象需要实现serializable接口,transiend修饰的变量不进行序列化
ObjectOutputStream.writObject()//序列化
ObjectInputStream.readObject()//反序列化
网络操作
- Socket
NIO
高速的面向块的IO
一次处理数据块,比按流处理要快,但是面向块的IO缺少一些面向流IO所具有的优雅性和简单性
- 通道
通道Channel是对原IO包中的流的模拟,可以通过他读取和写入数据。
通道与流的区别是,流操作都是单向的如InputStream/OutputStream,而通道是双向的,一个Channel就可完成读写两个操作
- FileChannel 从文件中读写数据
- DatagramChannel 通过UDP读写网络数据
- SocketChannel 通过TCP读写网络数据
- ServerSocketChannel 监听新进来的TCP链接,对每一个新的连接都会创建一个SocketChannel
- 缓冲区
通道在读写数据之前,都需要将目标对象放入到缓冲区中,缓冲区实质是一个数组,提供了对数据的结构化访问,还可以跟踪系统的读写进程
- ByteBuffer
- CharBuffer
- ShortBuffer
- IntBuffer
- LongBuffer
- FloatBuffer
- DoubleBuffer
网友评论