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);

原文地址:https://www.cnblogs.com/wjhblogs/p/4304826.html