• PrintStream


    PrintStream:

    是一个字节打印流,System.out对应的类型就是PrintStream。

    它的构造函数函数可以接收三种数据类型的值。

    1.字符串路径。

    2.File对象。

    3.OutputStream。


    PrintWriter:

    是一个字符打印流。构造函数可以接收四种类型的值。

    1.字符串路径。

    2.File对象。

    对于1,2类型的数据,还可以指定编码表。也就是字符集。


    3.OutputStream

    4.Writer

    对于3,4类型的数据,可以指定自动刷新。

    注意:该自动刷新值为true时,只有三个方法可以用:println,printf,format.

    //如果想要既有自动刷新,又可执行编码。如何完成流对象的包装?

    PrintWriter pw =

    new PrintWriter(new OutputStreamWriter(new FileOutputStream("a.txt"),"utf-8"),true);


    //如果想要提高效率。还要使用打印方法。

    PrintWriter pw =

    new PrintWriter(new BufferdWriter(new OutputStreamWriter(new FileOutputStream("a.txt"),"utf-8")),true);

    PipedInputStream

    PipedOutputStream


    特点:

    读取管道流流和写入管道流可以进行连接。

    连接方式:

    1.通过两个流对象的构造函数。

    2.通过两个对象的connect方法。


    通常两个流在使用时,需要加入多线程技术,也就是让读写同时运行。

    注意;对于read方法。该方法是阻塞式的,也就是没有数据的情况,该方法会等待。
    序列流,也称为合并流——SequenceInputStream:

    特点:可以将多个读取流合并成一个流。这样操作起来很方便。

    原理:其实就是将每一个读取流对象存储到一个集合中。最后一个流对象结尾作为这个流的结尾。


    两个构造函数:

    1.SequenceInputStream(InputStream in1,InputStream in2)

    可以将两个读取流合并成一个流。

    2.SequenceInputStream(Enumeration<? extends InputStream> en)

    可以将枚举中的多个流合并成一个流。

    作用:可以用于多个数据的合并。

    想要合并使用SequenceInputStream即可。对于切割后,合并是需要的一些源文件的信息。

    可以通过配置文件进行存储。该配置可以通过键=值的形式存在。

    然后通过Properties对象进行数据的加载和获取。


    操作数组的流对象

    1.操作字节数组

                    +

                      ByteArrayInputStream
                    +

                      ByteArrayOutputStream

    toByteArray();

    toString();

    writeTo(OutputStream);

    2.操作字符数组。

                    +

                      CharArrayReader
                    +

                      CharArrayWriter

    3.操作字符串

                    +

                      StringReader,
                    +

                      StringWriter。


    对于这些流,源是内存。目的也是内存。


    而且这些流并未调用系统资源。使用的就是内存中的数组。

    所以这些在使用的时候不需要close。


    操作数组的读取流在构造是,必须要明确一个数据源。所以要传入相对应的数组。


    对于操作数组的写入流,在构造函数可以使用空参数。因为它内置了一个可变长度数组作为缓冲区。


    这几个流的出现其实就是通过流的读写思想在操作数组。



    复合类型数据(比如:姓名、年龄、籍贯、性别等等)

    编码转换

    在io中涉及到编码转换的流是转换流和打印流。

    但是打印流只有输出。


    在转换流中是可以指定编码表的。

    默认情况下,都是本机默认的码表GBK. 这个编码表怎么来的?

    System.out.println(System.getProperty("file.encoding"));


    常见码表:

    ascii:美国标准信息交换码。使用的是1个字节的7位来表示该表中的字符。


    ISO8859-1:拉丁码表。使用1个字节来表示。


    GB2312:简体中文码表。

    GBK:简体中文码表,比GB2312融入更多的中文文件和符号。


    unicode:国际标准码表。都用两个字节表示一个字符。

    UTF-8:对unicode进行优化,每一个字节都加入了标识头。



    编码转换:

    字符串 -->字节数组 :编码。通过getBytes(charset);

    字节数组-->字符串: 解码。通过String类的构造函数完成。String(byte[],charset);

  • 相关阅读:
    Mac 实用工具——迁移助理
    Mac OS 的终端工具 iTerm2 的使用及设置
    Python3的异常捕获和处理
    Python3 文件的重命名
    Linux下jetty的启动和停止
    MySQL使用select查询时,在查询结果中增加一个字段并指定固定值
    使用ThreadLocal请务必remove
    Vue基础-文本显示,v-html插入html代码
    nginx之location(root/alias)&& linux 上修改了nginx.conf 怎么重新加载配置文件生效
    CentOS7开启防火墙及特定端口
  • 原文地址:https://www.cnblogs.com/wjhblogs/p/4304826.html
Copyright © 2020-2023  润新知