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

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

`

© 简单ai... 中级黑马   /  2013-10-22 16:59  /  1345 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 简单ai... 于 2016-3-26 01:23 编辑

复制代码

评分

参与人数 1技术分 +1 收起 理由
李江 + 1 很给力!

查看全部评分

3 个回复

倒序浏览

写法一:
output.write(in);
in = input.read();
第一次读取字节,判断不是文件末尾,先将读取到的字节写入输出流。然后继续读取下一个字节。一读一写,最后复制文件成功。

写法二:
in = input.read();
output.write(in);
你要注意,你初始化in的时候就是要复制的文件的一个字节。在循环里这么写之后,如果不是文件末尾,那么将in原来的值覆盖掉,并赋予文件的
下一个字节。这个过程,你已经丢失了第一个字节没有复制过去。之后的每次循环,都会丢失一个字节,再复制一个字节,
最后复制成功的文件,解析的时候,GBK会按照两个字节来解读,要是对不上文字,那么就会乱码,表示未知字符。


你可以试下写法二复制字符,那么复制后的文件只是丢失第一个字符,后面的字符都复制成功。
你要坚持写法二的话,可以修改in的初始化的值为0.不是文件的字节就行。

希望能帮到你~~




回复 使用道具 举报
黄炳期 发表于 2013-10-22 17:37
写法一:
output.write(in);
in = input.read();

的确厉害,我也弄懂了,非常感谢:D
回复 使用道具 举报
简单ai... 发表于 2013-10-22 19:21
的确厉害,我也弄懂了,非常感谢

客气了。

如果问题已经解决,请及时修改主题至“提问结束”。
重新编辑帖子即可。
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马