讲解字符流的使用
字符输出流抽象类:
Writer
Reader
因为是抽抽象类我们不能直接使用,要使用他们的具体子类
OutputStreamWriter()
是从字符流到字节流的桥梁,就是把我们写的字符转化为字节进行存储,
他可以使用系统默认的编码格式对字符进行编码,构造方法
OutputStreamWriter(OutputStream outputStream);
注意这里的参数是OutputStream是一个抽象的字节输出流对象,我们要使用他的具体的字节输出流对象FileOutputStream
他也可以使用指定的编码格式对字符进行编码,构造方法
OutputStreamWriter(OutputStream outputStream , String chatsetName)
chatsetName 可以是GBK , UTF-8
InputStreamReader ()是从字节流到字符流的桥梁,就是把计算机存储的字节数据转化为文字显示出来
他可以使用系统默认的编码格式对字节数据进行解码,构造方法
InputStreamReader (InputStream inputStream);
他也可以使用指定的编码格式对字符进行解码,构造方法
InputStreamRreader(InputStream InputStream , String chatsetName)
代码
public static void main(String[] args) throws IOException {
//创建字节输出流对象
FileOutputStream fos = new FileOutputStream("C:\\Users\\Administrator\\IdeaProjects\\Day07\\a.txt");
//创建字符输出流对象 使用默认的编码格式写数据
//OutputStreamWriter osw = new OutputStreamWriter(fos); //打开a.txt显示的是 中国
//创建字符输出流对象 使用指定的编码格式写数据 默认是utf-8
OutputStreamWriter osw = new OutputStreamWriter(fos,"GBK");
//当我们打开a.txt文件的时候里面是乱码 , 因为我们把数据存储进去打开文件的时候 因为文件默认的是用utf-8
//所以显示乱码,但是我们通过 gbk吧数据解析出来的时候还是可以看到 中国 的
//写数据
osw.write("中国");
//释放资源
osw.close();
//使用字节输出流 因为上面我们使用的是gbk编码 这里我们要使用gbk解码
FileInputStream fis = new FileInputStream("C:\\Users\\Administrator\\IdeaProjects\\Day07\\a.txt");
//创建字节输入流对象指定解码格式是gbk
InputStreamReader isr = new InputStreamReader(fis ,"gbk");
//一个字符一个字符一个字符的读数据
int data;
while ((data = isr.read()) != -1){
System.out.println((char) data); //虽然此时a.txt文件里面是乱码但是还是解码出来了中国
}
}