本帖最后由 李会成 于 2013-2-18 11:26 编辑
做题的时候遇到字符流和字节流处理复制文本文件的一点小问题有点迷糊,请大家帮帮忙!
之前做基础测试的时候,有一题要我们写一个最快的复制文件的程序。于是我去查了一下,发现复制文件的处理方法可以通过字节流和字符流两种方式来处理。一般来说,二进制文件比如:音频之类的只能通过字节流来处理,文本文件[本质上也可以说是二进制文件]可以通过字符流和字节流两种方式来处理。但是在查资料的时候,看到有人说文本文件最好用字符流来处理,因为字节流提供了处理任何类型的IO操作的功能,但它不能直接处理Unicode字符,而字符流就可以。就是说,字节流处理Unicode编码的文件时有可能出现乱码。
然后我为了看看效果,就自己看着API编了一个小程序。实验用的文本文件里面的内容是unicode编码才能保存下来的字符。然后我分别用字节流方式和字符流方式来复制这个文件。
但是结果大大超出我的意料。字节流方式复制的文件里面的内容是正确的,相反字符流方式复制里面的内容则出现了乱码。难道是我看资料的时候理解错误了?但是API里面不也是叫处理文本文件的时候用FileReader类和FileWriter类么?
我把代码贴一下,大家帮我看看吧,我试验了好几个文件都是这样的。- import java.io.*;
- import java.util.Date;
- class TimeTest
- {
- public static void main(String[] args)
- {
- //计算通过字符流实现复制所耗费的时间
- try{
- long da1= (new Date()).getTime();
- BufferedReader bin = new BufferedReader(new FileReader("E:\\复件 Q.骑士.txt"));//读取文件内容
- PrintWriter pout = new PrintWriter(new BufferedWriter(new FileWriter("D:\\复件 Q.骑士.txt")));//向文件中写入内容
- String s1;
- while((s1 = bin.readLine())!=null)
- {
- pout.write(s1);
- }
- bin.close();
- pout.close();
- long da2= (new Date()).getTime();
- System.out.println("通过字符流实现复制所耗费的时间:"+(da2-da1));
- }catch(FileNotFoundException e1){
- e1.printStackTrace();
- }catch(IOException e2){
- e2.printStackTrace();
- }
- //计算通过字节流实现复制操作所耗费的时间
- try
- {
- long da3= (new Date()).getTime();
- FileInputStream fin = new FileInputStream("E:\\Q.骑士.txt");
- FileOutputStream fout = new FileOutputStream("D:\\Q.骑士.txt");
- byte[] buffer = new byte[1024*2];
- int bytelenth = fin.read(buffer);
- while(bytelenth!=-1)
- {
- fout.write(buffer,0,bytelenth);
- bytelenth = fin.read(buffer);
- }
- fin.close();
- fout.close();
- long da4= (new Date()).getTime();
- System.out.println("通过字节流实现复制所耗费的时间:"+(da4-da3));
- } catch(FileNotFoundException e1){
- e1.printStackTrace();
- }catch(IOException e2){
- e2.printStackTrace();
- }
- }
- }
复制代码 我觉得问题是出在复制过去的文件的编码上请看下图:字符流复制了文件之后文件的编码变成ANSI的了。
内容.zip
(419 Bytes, 下载次数: 245)
|
|