4,160
社区成员




1.程序可以处理的数据来源除了文件还有哪些?对不同的数据来源共同的操作是什么?
数据库,网络等等
读与写操作
2.将对不同数据源中数据的读写抽象为对流的读写,有什么好处?
读写时只对流操作,无需关心具体实现的过程,可以使用统一的接口与方法,提高读写的效率。
3.二进制文件与文本文件有什么区别?字节流与字符流之间有什么关系?为什么有的文本文件打开会乱码?怎么解决?
1、文本文件是基于字符编码的文件,常见的编码有ASCII编码,UNICODE编码等;二进制文件是基于值编码的文件
2.字节流的数据存储单位是字节,会使用字节类型数组 byte[] 来保存数据,可以操作字节,字节数组。而字符流的存储单位是字符,使用字符类数组 char[] 来保存数据,可以操作字符,字符数组或字符串。
3.FileReader按照系统默认字符集(GBK)读取UTF-8编码的文件,使用InputStreamReader建立字节流与字符流的桥梁
4.字符与字节之间的关系是什么?尝试使用Visual Studio Code的Hex Editor插件打开一个文本文件。在文本文件中输入"123abc中文"。观察:一个英文字符占几个字节,一个中文字符占用几个字节。在Java程序中,使用字节流怎么将这个文件中的数据正确读取并组装起来。
不同编码里,字符和字节的对应关系不同:
1.ASCII码中,一个英文字母(不分大小写)占一个字节的空间,一个中文汉字占两个字节的空间。一个二进制数字序列,在计算机中作为一个数字单元,一般为8位二进制数,换算为十进制。最小值0,最大值255。
2.UTF-8编码中,一个英文字符等于一个字节,一个中文(含繁体)等于三个字节。
3.Unicode编码中,一个英文等于两个字节,一个中文(含繁体)等于两个字节。
符号:英文标点占一个字节,中文标点占两个字节。举例:英文句号“.”占1个字节的大小,中文句号“。”占2个字节的大小。
4.UTF-16编码中,一个英文字母字符或一个汉字字符存储都需要2个字节(Unicode扩展区的一些汉字存储需要4个字节)。
5.UTF-32编码中,世界上任何字符的存储都需要4个字节。
2. ASCII 码中,一个英文字母(不分大小写)为一个字节,一个中文汉字为两个字节。
• UTF-8 编码中,一个英文字为一个字节,一个中文为三个字节。
• Unicode 编码中,一个英文为一个字节,一个中文为两个字节。
• 符号:英文标点为一个字节,中文标点为两个字节。例如:英文句号 . 占1个字节的大小,中文句号 。占2个字节的大小。
• UTF-16 编码中,一个英文字母字符或一个汉字字符存储都需要 2 个字节(Unicode 扩展区的一些汉字存储需要 4 个字节)。
• UTF-32 编码中,世界上任何字符的存储都需要 4 个字节。
5.有一个stus数组,里面有若干Student对象(String name, int age, boolean gender, double score)。要将这些对象高效率地存储到文件中,需要使用哪些流?使用二进制流与使用字符流将这个数组存储到文件有何不同?使用二进制流与使用字符流从文件中读取并组装成对象有何不同?
使用FileOutputStream文件流,BufferedOutputStream缓冲流,ObjectOutputStream字节流
二进制流都是以01的编码存储,字符流都是以字符串的形式
6.使用什么类可以对文件进行随机存取?读写的单位是什么?为什么不是字符呢?
RandomAccessFile支持对文件的随机读写,byte字节,