我正在处理Java中的I/O类。我知道有两种重要的流类型:字节流和字符流。但是..。我试着用字节流来读取和写入文本文件,它起了作用。以下是代码:
File klasor = new File("C:\\Java");
if(!klasor.exists()) klasor.mkdirs();
File kaynakDosya = new File("C:\\Java\\kaynak.txt");
if(!kaynakDosya.exists()) kaynakDosya.createNewFile();
File hedefDosya = new File("C:\\Java\\hedef.txt");
if(!hedefDosya.exists()) hedefDosya.createNewFile();
FileInputStream kaynak = new FileInputStream(kaynakDosya);
FileOutputStream hedef = new FileOutputStream(hedefDosya);
int c;
while((c = kaynak.read()) != -1) {
hedef.write(c);
}
if(kaynak != null) {
kaynak.close();
}
if(hedef != null) {
hedef.close();
}然后我对字符流做了同样的处理:
File klasor = new File("C:\\Java");
if(!klasor.exists()) klasor.mkdirs();
File kaynakDosya = new File("C:\\Java\\kaynak.txt");
if(!kaynakDosya.exists()) kaynakDosya.createNewFile();
File hedefDosya = new File("C:\\Java\\hedef.txt");
if(!hedefDosya.exists()) hedefDosya.createNewFile();
FileReader kaynak = new FileReader(kaynakDosya);
FileWriter hedef = new FileWriter(hedefDosya);
int c;
while((c = kaynak.read()) != -1) {
hedef.write(c);
}
if(kaynak != null) {
kaynak.close();
}
if(hedef != null) {
hedef.close();
}这两者产生了同样的结果。所以,我想知道,为什么这里不应该使用字节流,而应该使用字符流?(我在这里读过一些关于堆栈溢出的文章和相关问题,他们是这么说的)我知道字符流会逐个读,但这给我带来了什么好处呢?或者,如果我使用字节流读取字符,会发生什么问题?我希望我的问题很清楚。我希望能举个实例。
发布于 2017-10-22 13:54:46
java.io.FileInputStream javadoc声明:
FileInputStream用于读取原始字节流(如图像数据)。要读取字符流,请考虑使用FileReader。
java.io.FileOutputStream javadoc声明了一些类似的内容:
FileOutputStream用于写入原始字节流(如图像数据)。要编写字符流,请考虑使用FileWriter。
FileInputStream/FileOutputStream和FileReader/FileWriter的主要区别之一是,第一个提供了操作字节的方法,而后者提供了操作字符的方法。
在您的示例中,当您将文件内容复制到另一个文件时,操作char或byte并没有太大的区别。
在您的例子中,FileInputStream或BufferedInputStream似乎更合适。
但是,如果您使用流从/向String实例中读取/写入字符,那么使用FileReader/FileWriter可以真正简化事情,使事情变得更清楚。
此外,您还可以将FileReader/FileWriter封装到一个BufferedReader/BufferedWriter中,并从高效地读取/写入字符、数组和行中获益。
BufferedWriter writer = new BufferedWriter(new FileWriter("myfile"));
writer.append(oneString);
writer.append(oneStringBuffer);
writer.newLine();
BufferedReader reader = new BufferedReader(new FileReader("myfile"));
String currentLine = reader.readLine();发布于 2017-10-22 13:54:53
将字符写入面向字节的输出流(或从面向字节的输入流中读取字符)将产生与使用面向字符的流相同的结果,只有在平台的默认编码中,流中的所有字符都可以用单个字节表示(通常是UTF-8,但也可以是其他字符)。要测试这一点,请尝试包含一个需要多个字节来表示的文件(如希腊语、西里尔字母或阿拉伯字符)。有了一个面向字节的流,这些就不能工作了。对于面向字符的流,只要两个流都使用支持这些字符(例如UTF-8)的编码,并且输入文件存储在用于输入流的编码中,则字符将被保留。
请注意,您的面向字节的代码实际上并没有测试这一点,因为它只是在逐字节复制文件。一切看起来都正常,但如果您试图读取实际字符(例如,将它们与代码中的实际文本进行比较,则会失败。要测试这一点,请创建一个包含西里尔文本"Привет!“的文件(例如,UTF-8编码)。然后,在代码中,尝试使用面向字节的输入流将文本读取到String中,并测试它是否包含您期望使用的内容。
System.out.println("Success: " + "Привет!".equals(input));https://stackoverflow.com/questions/46874783
复制相似问题