减少底层调用,提高效率
用缓冲区写数据
看源码,调用缓冲区构造器的时候创建了一个大小为8192字节的数组存数据作为缓冲
缓冲区读数据
复制avi视频
使用System.currentTimeMillis();计算时长
为什么要用字符流?
GBK编码占用2个字节,UTF-8编码占用3个字节
这种拿到一个字节就读了就出问题了
字节流复制中文不出问题的原因:
因为中文无论是按照GBK--2字节还是UTF-8--3字节编码,第一个字节都会是负数,这样系统按照编码方式转译
字符流的底层还是字节流
编码表
编码解码问题
字符流的编码解码问题
InputStreamReader类
同理OutputStreamWriter类
编码构造器
如果后面是GBK,打开文件就会出现乱码,因为文件的编码方式是UTF-8,而指定了GBK的编码方式,所以出现乱码
但如果用GBk的方式去解码就能顺利读出来
把用GBK编码的文件按默认UTF-8解码
把用GBK编码的文件按GBK解码
字符流写数据
直接这么写写不进去文件,因为字符流通过字节流去写,数据现在存在缓冲区里,需要刷新缓冲,用flush()方法
但如果不写刷新在后面写关闭也行,因为close方法是先刷新缓冲再释放资源,但close方法后面不能继续写数据
字符流读数据