我们对于文件中数据的操作无非就有两种:读出与写入
对于Java来说,对数据的操作有字节流(FileOutputStream、FileInputStream)与字符流(FileWriter、FileReader),这两种方法其实差不多,都是从文件中写入数据或读出数据,他俩的区别就是字节流是以字节为单位进行操作的,而字符流是以字符为单位进行操作的。
我们都知道一个英文字母占一个字节,一个中文汉字占两个字节,而一个英文字母与一个中文汉字我们都称之为一个字符,所以说我们要根据文件中所存储的数据内容的不同而选择不同的操作方法。
假如说我们一个文本文档中存储了这样一句话:
321爱就像蓝天白云,晴空万里,突然暴风雨!
这句话中有数字、汉字以及标点符号,
数字:1个字节
中文汉字:2个字节
中文标点符号:2个字节
英文标点符号:1个字节
而他们都属于1个字符
如果我们使用字节流来进行读取文件的操作,部分代码如下
FileInputStream in;
try {
in=new FileInputStream(file);
byte bytRead[]=new byte[1024];
int len=in.read(bytRead);
System.out.println("文件中的内容是:"+new String(bytRead,0,4));//注意这里我们只读取了文件中的前四个字节
in.close();
}catch(IOException e) {
e.printStackTrace();
}
输出结果为:
文件中的内容是:321?
我们发现前面三个数字可以正常输出,但是文本中的“我”却没有正常输出,而是输出了一个“?”,这就是字节流的特点,它是以字节为单位来进行操作的,他只输出了前4个字节的内容,而“321我”是5个字节,所以“我”没有被正常输出出来
然后我们再来看字符流的操作,部分代码如下
FileReader fr=null;
try {
fr=new FileReader(file);
char chRead[]=new char[1024];
int hasread=-1;
try {
while((hasread=fr.read(chRead))!=-1) {//hasread表示文本中的字符数
System.out.println("文件中的内容是:"+new String(chRead,0,hasread));
}
} catch (IOException e) {
e.printStackTrace();
}
}catch(FileNotFoundException e) {
e.printStackTrace();
}finally {
try {
fr.close();
} catch (IOException e) {
e.printStackTrace();
}
}
输出结果:
文件中的内容是:321爱
我们发现在输出的时候,传入的参数同样都是4,而我们此时用字符流进行操作的时候就可以完整把原数据输出出来
字节流:
System.out.println("文件中的内容是:"+new String(bytRead,0,4));
字符流:
System.out.println("文件中的内容是:"+new String(chRead));
以上就是字节流与字符流的主要区别,对于FileOutputStream和FileWriter也是同样的道理,只不过他们两个是对文件进行写入的操作。我们只要清楚他们操作的单位不一样就可以了:
字节流:以字节为单位进行数据操作
字符流:以字符为单位进行数据操作
注:
1、我们用字节流来操作的时候,创建的是字节型的数组来存储读出来的数据
byte bytRead[]=new byte[1024];
我们用字符流来操作的时候,创建的是字符型的数组来存储读出来的数据
char chRead[]=new char[1024];
2、一定要区分开哪一个是写入,哪一个是读出
写入:
FileOutputStream
FileWriter
读出:
FileInputStream
FileReader