zoukankan      html  css  js  c++  java
  • java IO流分析整理

    java中的流,从输入输出方向分为  输入流(数据从文件流向内存),输出流(数据流出内存到文件).

    java中的流,可以从不同的角度进行分类。

    按照数据流的方向不同可以分为:输入流和输出流。

    按照处理数据单位不同可以分为:字节流和字符流。

    按照实现功能不同可以分为:节点流和处理流。

    输出流:

     

    输入流:

    因此输入和输出都是从程序的角度来说的。

    字节流:一次读入或读出是8位二进制。

    字符流:一次读入或读出是16位二进制。

    字节流和字符流的原理是相同的,只不过处理的单位不同而已。后缀是Stream是字节流,而后缀是Reader,Writer是字符流。

    节点流:直接与数据源相连,读入或读出。

    直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。

    处理流:与节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。

    Jdk提供的流继承了四大类:InputStream(字节输入流),OutputStream(字节输出流),Reader(字符输入流),Writer(字符输出流)。

    以下是java中io中常用的流。

    字节输入流:

    字节输出流:

    字符输入流:

    字符输出流:

    简单介绍其上图:

    对文件进行操作:FileInputStream(字节输入流),FileOutputStream(字节输出流),FileReader(字符输入流),FileWriter(字符输出流)

    对管道进行操作:PipedInputStream(字节输入流),PipedOutStream(字节输出流),PipedReader(字符输入流),PipedWriter(字符输出流)

    PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操作。主要用于线程操作。

    字节/字符数组:ByteArrayInputStream,ByteArrayOutputStream,CharArrayReader,CharArrayWriter是在内存中开辟了一个字节或字符数组。

    Buffered缓冲流::BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter,是带缓冲区的处理流,缓冲区的作用的主要目的是:避免每次和硬盘打交道,提高数据访问的效率。

    转化流:InputStreamReader/OutputStreamWriter,把字节转化成字符。

    数据流:DataInputStream,DataOutputStream。

    因为平时若是我们输出一个8个字节的long类型或4个字节的float类型,那怎么办呢?可以一个字节一个字节输出,也可以把转换成字符串输出,但是这样转换费时间,若是直接输出该多好啊,因此这个数据流就解决了我们输出数据类型的困难。数据流可以直接输出float类型或long类型,提高了数据读写的效率。

    打印流:printStream,printWriter,一般是打印到控制台,可以进行控制打印的地方。

    对象流:ObjectInputStream,ObjectOutputStream,把封装的对象直接输出,而不是一个个在转换成字符串再输出。

    序列化流:SequenceInputStream。

    对象序列化:把对象直接转换成二进制,写入介质中。

    使用对象流需要实现Serializable接口,否则会报错。而若用transient关键字修饰成员变量,不写入该成员变量,若是引用类型的成员变量为null,值类型的成员变量为0.

  • 相关阅读:
    Kubernetes(十一) 部署doshboard
    kubernetes(一)kubeadm安装
    kubernetes安装-二进制
    使用Jmeter+Maven+Jenkins实现接口自动化测试
    使用Jmeter在linux环境实现分布式负载
    Jmeter连接Mysql和Oracle数据库
    Jmeter如何实现参数化用户,并且管理Cookie
    开启MYSQL慢查询日志,监控有效率问题的SQL
    使用jmeter+ant+jenkins实现接口自动化测试
    使用Jmeter对SHA1加密接口进行性能测试
  • 原文地址:https://www.cnblogs.com/hadoop-dev/p/8333996.html
Copyright © 2011-2022 走看看