IO、NIO

作者: battle_ | 来源:发表于2018-04-03 19:50 被阅读87次

    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
    

    相关文章

      网友评论

          本文标题:IO、NIO

          本文链接:https://www.haomeiwen.com/subject/sqiocftx.html