Java中的IO流②——字符集、字符流、缓冲流

主要的编码规范:

GBK编码

Windows自带


Unicode编码


为什么会有乱码?

原因一

原因二


编码和解码的代码实现


字符流

FileReader

read()细节:

一:默认也是一个字节一个字节的读取,如果遇到中文就会一次读取多个

二:在读取之后,方法的底层还会进行解码并转成十进制

        最终把这个十进制作为返回值

        这个十进制的数据也表示在字符集上的数字

        英文:文件里面二进制数据 0110 0001

                read方法进行读取,解码并转成十进制97

        中文:文件里面二进制数据 11100110 10110001 10001001

                read方法进行读取,解码并转成十进制27721

        想看到中文汉字,就是要把这些十进制数据,再进行char强转就可以了

read(chars):读取数据,解码,强转三步合并了,把强转之后的数据存放到数组当中

                = 空参的read+强转

FileWriter

构造方法

成员方法

书写细节

原理解析

输入流

输出流

flush和close


字节流和字符流的使用场景


缓冲流

字节缓冲流

构造方法

字符缓冲流

构造方法

特有方法

总结


  • 6
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值