字符编码
ASCII:
- 美国标准信息交换码
- 用一个字节的7位可以表示
- 65 A . 97 a
ASCII码表
ISO8859-1:
- 拉丁码表。欧洲码表
- 用一个字节的8位表示。
GB2312:
- 中国的中文编码表。最多两个字节编码所有字符
GBK:
- 中国的中文编码表升级,融合了更多的中文文字符号。
- 最多两个字节编码
Unicode:
- 国际标准码,融合了目前人类使用的所有字符。为每个字符分配唯一的字符码。
- 所有的文字都用两个字节来表示。
UTF-8:
- 变长的编码方式,可用1-4个字节来表示一个字符。
- 中文一般是用三个字节
补充:
@Test
public void test2() throws Exception {
//1.造文件、造流
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 osw = new OutputStreamWriter(fos,"gbk");
//2.读写过程
char[] cbuf = new char[20];
int len;
while((len = isr.read(cbuf)) != -1){
osw.write(cbuf,0,len);
}
//3.关闭资源
isr.close();
osw.close();
}