对于PrintStream 和PrintWriter的理解 以及各种编码格式 以及编码和解码的解释

PrintStream

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

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

1,字符串路径。

2File对象。

3OutputStream


PrintWriter

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

1,字符串路径。

2File对象。

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

操作数组的流对象

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






猜你喜欢

转载自blog.csdn.net/huxiaochao_6053/article/details/53861435
今日推荐