什么是字符输出转换流?
位于api文档中的java.io.OutputStreamWriter
下,该流是字符流通向字节流的桥梁,可以使用指定的charset将要写入流中的字符编码成字节。(这是个编码的过程,把能看懂的字符转换为看不懂的字节)
字符输出转换流继承字符流,所以能使用字符输出流中的方法
字符输出转换流中的构造方法:
OutputStreamWriter(OutputStream out)
创建使用默认字符编码的 OutputStreamWriterOutputStreamWriter(OutputStream out, String charsetName)
创建使用指定字符集的 OutputStreamWriter
其中参数的含义为
- OutputStream out:传递的是字节输出流,可以用来把转换之后的字节写入到文件当中
- String charsetName:指定编码表名称,不区分大小写,不指定编码表的话默认是utf-8
字符输出转换流的使用步骤
- 创建OutputStreamWriter对象,构造方法中传递字节输出流和指定的编码名称
- 使用OutputStreamWriter对象中的Write方法,把字符转换为字节存储到缓冲区中(其实这个过程就是把字符转换为字节码的过程)
- 使用OutputStreamWriter对象中的flush,把内存缓冲区中的字节刷新到文件中(这个过程中通过字节输出流将,缓冲区中的字节码转换为对应的字符,然后存入到文件当中)
- 释放资源(可以不单独写flush方法,因为默认使用close方法也会自动将缓冲区中的字节刷新到文件当中)
举例示范
public static void main(String[] args) throws IOException {
// 1. 创建OutputStreamWriter对象,构造方法中传递字节输出流和指定的编码名称
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("d:\\c.txt"), "utf-8");
// 2. 使用OutputStreamWriter对象中的Write方法,把字符转换为字节存储到缓冲区中(其实这个过程就是把字符转换为字节码的过程)
osw.write("你好");
// 释放资源(可以不单独写flush方法,因为默认使用close方法也会自动将缓冲区中的字节刷新到文件当中)
osw.close();
}
结果如下:
并且占用六个字节,因为utf-8编码表中一个中文占三个字节,GBK编码表中一个中文占两个字节