字符流是否来自于转换流,为什么?

版权声明:随便转载了.............. https://blog.csdn.net/lijingshan34/article/details/78071454

转换流可以将字节转成字符,原因在于,将获取到的字节通过查编码表获取到指定对应字符。
转换流的最强功能就是基于 字节流 + 编码表 。没有转换流就没有字符流。
转换流InputStreamReader,OutputStreamWriter各有一个子类就是操作文件的字符流对象FileReader,FileWrier:
想要操作文本文件,必须要进行编码转换,而编码转换动作转换流都完成了。
所以操作文件的流对象只要继承自转换流就可以读取一个字符了。
但是子类有一个局限性,就是子类中使用的编码是固定的,是本机默认的编码表,对于简体中文版的系统默认码表是GBK。
FileReader fr = new FileReader(“a.txt”);
InputStreamReader isr = new InputStreamReader(new FileInputStream(“a.txt”),”gbk”);
以上两句代码功能一致,
如果仅仅使用平台默认码表,就使用FileReader fr = new FileReader(“a.txt”); //因为简化。
如果需要制定码表,必须用转换流。
转换流 = 字节流+编码表。
转换流的子类File = 字节流 + 默认编码表。
凡是操作设备上的文本数据,涉及编码转换,必须使用转换流。

猜你喜欢

转载自blog.csdn.net/lijingshan34/article/details/78071454