一、转换流涉及到的类:都是字符流
InputStreamReader:将输入的字节流转换为输入的字符流。
解码:字节、字节数组 ————>字符串、字符数组
OutputStreamWrite:将输出的字符流转换为输出的字节流。
编码:字符串、字符数组 ————>字节、字节数组
二、作用
转换流提供字节流和字符流之间的转换。字节流中的数据都是字符时,转成字符流操作更高效。 很多时候我们使用转换流来处理文件乱码问题。实现编码和 解码的功能。
三、典型代码实现
@Test
public void test1() throws IOException {
FileInputStream fis = new FileInputStream("dbcp.txt");
// InputStreamReader isr = new InputStreamReader(fis);//使用系统默认的字符集
//参数2指明使用的字符集,使用哪个字符集取决于指定文件保存的格式
InputStreamReader isr = new InputStreamReader(fis,"UTF-8");
char[] cbuf = new char[20];
int len;
while((len = isr.read(cbuf)) != -1){
String str = new String(cbuf,0,len);
System.out.print(str);
}
isr.close();
}
//实践中要进行try-catch处理,不要throws,这里偷懒了
/*
综合使用InputStreamReader和OutputStreamWrite
*/
@Test
public void test2() throws IOException {
File file1 = new File("dbcp.txt");
File file2 = new File("dbcp_gbk.txt");
FileInputStream fis = new FileInputStream(file1);
FileOutputStream fos = new FileOutputStream(file2);
InputStreamReader isr = new InputStreamReader(fis,"utf-8");
OutputStreamWriter osr = new OutputStreamWriter(fos,"gbk");
char[] cbuf = new char[10];
int len;
while((len = isr.read(cbuf)) != -1){
osr.write(cbuf,0,len);
}
isr.close();
osr.close();
}
四、说明
编码时的字符集(比如gbk),决定了解析时的字符集类型(只能是gbk),否则会出现乱码等错误。
五、编码集
1、常见的编码表
ASCII:美国标准信息交换码。用一个字节的7位可以表示。
ISO8859-1:拉丁码表。欧洲码表用一个字节的8位表示。
GB2312:中国的中文编码表。最多两个字节编码所有字符
GBK:中国的中文编码表升级,融合了更多的中文文字符号。最多两个字节编码
Unicode:国际标准码,融合了目前人类使用的所字符。为每个字符分配唯一的字符码。所有的文字都用两个字节来表示。
UTF-8:变长的编码方式,可用1-4个字节来表示一个字符。
2、对后面学习的启示
客户端、浏览器端 <——> 后台(java\pathoy、Node.js...)<——> 数据库
要求前后的字符集保持一致:UTF-8。