A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 张晴 黑马帝   /  2011-7-29 22:29  /  2200 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

我自己写了一个拷贝文件的方法,我想让它一次读取一行,一行行的写入目标文件,用了BufferedReader、 BufferedWriter包装类包装底层流,拷贝.txt类型的文件没有异常,但拷贝.doc文件时,出现错误,怎么回事呢?方法如下:
  1. private static void fileCopy(File srcfile, File destfile)
  2.                         throws IOException, FileNotFoundException{
  3.                 destfile.createNewFile();
  4.                  FileReader fr=new FileReader(srcfile);
  5.                  BufferedReader br=new BufferedReader(fr);
  6.                  FileWriter fw=new FileWriter(destfile);
  7.                  BufferedWriter bw=new BufferedWriter(fw);
  8.                  String str=null;
  9.                  while((str=br.readLine())!=null)
  10.                  {
  11.                          bw.write(str);
  12.                          bw.newLine();
  13.                  }
  14.                  br.close();
  15.                  bw.flush();
  16.                  bw.close();
  17.        
  18.         
  19.         }
复制代码

3 个回复

倒序浏览
黑马网友  发表于 2011-7-29 23:37:06
沙发
有没有知道????

评分

参与人数 1技术分 +1 收起 理由
admin + 1 继续等待!

查看全部评分

回复 使用道具 举报
IO流分为两大类:字节流与字符流。
字节流多用于二进制的文件,如jpg、png、mp3、rmvb、doc、exe等等格式的二进制文件,如果用字符流对这些
    文件进行读写操作,会出现乱码。
字符流:用于读写字符串文件,如txt。
Reader 的read()方法读取的是一个字符(一个字符占2个字节)。
Reader 与 Writer是字符流。
字符流处理的单元为2个字节的Unicode字符,分别操作字符、字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组。所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,所以它对多国语言支持性比较好!如果是音频文件、图片、歌曲,就用字节流好点,如果是关系到中文(文本)的,用字符流好点。
      所有文件的储存是都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以形成字节序列。

      字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串; 2. 字节流提供了处理任何类型的IO操作的功能,但它不能直接处理Unicode字符,而字符流就可以。
        字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的。
Reader类的read()方法返回类型为int :作为整数读取的字符(占两个字节共16位),范围在 0 到 65535 之间 (0x00-0xffff),如果已到达流的末尾,则返回 -1。
inputStream的read()虽然也返回int,但由于此类是面向字节流的,一个字节占8个位,所以返回 0 到 255 范围内的 int 字节值。如果因为已经到达流末尾而没有可用的字节,则返回值 -1。因此对于不能用0-255来表示的值就得用字符流来读取!比如说汉字...至此,有些人可能就会产生一个问题:既然返回结果只能在0-255之间的值,那何返回byte型的呢? 这个问题提得很好,我先顶你一下~~~也就是说一个int占4个字节,而返回结果只是在0-255(2的8次方-1)之间,只占1个字节,这就说明返回结果只占掉int的低8位!其实是这样的:
read()有个约定,就是达到流的结尾时返回-1 ,而byte型的范围是0-255(没有负数)。因此-1会被表示成255!这样,如果返回类型是byte,那么255究竟是代表 结束 还是代表 读到的byte值 呢? 显然无法区分!
[code=java]public class test2 {
       
        private static void fileCopy(File srcfile, File destfile)        throws IOException, FileNotFoundException{
                destfile.createNewFile();
       
                FileInputStream fis = new FileInputStream(srcfile);
                FileOutputStream fos = new FileOutputStream(destfile);
               
               
                byte[] buf = new byte[1024*8];//buf.length可以随意设置,如1024*8
                int len = 0;
                while((len= fis.read(buf))!=-1){ //用输入流fis一次读取1024个字节的内容存放到字节数组buf中,如果文件没1024字节,则一次读完。
                       
                        System.out.println(len);
                       
                        fos.write(buf);  //把buf字节数组的当前读取到的内容写入到输出流fos中
               
                                               
                }
               
                fis.close();
                fos.close();
               


}
       
        public static void main(String[] args) {
               
               
                File srcfile = new File("F:/ie10preview.msi");
                File destfile = new File("d:/2.msi"); //复制了ie10,安装成功了。
                try {
                        fileCopy(srcfile, destfile);
                } catch (FileNotFoundException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                } catch (IOException e) {
                        // TODO Auto-generated catch block
                        e.printStackTrace();
                }
        }


}[/code]
[ 本帖最后由 覃俊瑞 于 2011-07-30  01:55 编辑 ]

评分

参与人数 1技术分 +1 收起 理由
老罗 + 1

查看全部评分

回复 使用道具 举报
黑马网友  发表于 2011-7-30 03:26:28
板凳
张老师的课Java_高级_02_05.swf 第16分钟左右讲到了文本文件与二进制文件的区别。二进制文件与文本文件的区别:严格说系统中的每个文件都是二进制文件,文本文件是二进制文件的一个特例,对应的每个字节的数字不能是任意的。仔细听这段你可能就明白了。  因为readLine() 读取的是一个文本行。详见jdk API文档。所以当用readLine() 读取一个非文本文件是自然是错的。不知道这个答案对不对。

评分

参与人数 1技术分 +2 收起 理由
老罗 + 2 3点还在学习,加1分,看视频很认真,加1分。

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马