码迷,mamicode.com
首页 > 其他好文 > 详细

read(char[] b,int off,int len) 和read(char[] b)的区别

时间:2014-12-14 10:45:19      阅读:125      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   ar   使用   sp   java   on   文件   

今天在读取文件里的十六进制数据的时候,采用java的read(char[] b)方法进行读取,结果发现打印的数据和文件里的数据结尾不一致。后来一看还有一个read(char[] b,int off,int len) 方法。就去查了一个它们的区别,正好read(char[] b,int off,int len) 可以解决我的问题。下面是网上参考的资料,很容易懂。
这是read(char cbuf[])方法的源码,可以看出,read方法其实是调用了read(char[] b,int off,int len)这个方法,只不过是将len设为数组的长度
public int read(char cbuf[]) throws IOException {
return read(cbuf, 0, cbuf.length);
}
再看看read(char[] b,int off,int len) 这个方法,源码有些复杂,就不看了,大概的意思是说:将字符读入数组的某一部分,len为要读取的最多字符数,当然可以比他小。
现在举个例子,比如一个文件有1024+40个字节,用read(char cbuf[])第一次往数组中读取了1024个字节,第二次也必须读取1024个字节,因为数
组长度就为1024,但是他只有40个字节了。这个时候前40个字节会被覆盖,而后面的字节还是上一次数组中的。
而read(char[] b,int off,int len) 这个方法就不一样了,第一次他读取了1024个字节,第二次他看见不够,就读取40个字节往数组中,剩下的
空间是空的。
所以我们在平时的读写文件时,尽量使用下面的代码(如果是二进制换为byte数组)
char[] buff=new char[1024];
int i=0;
while((i=reader.read(buff,0,1024))!=-1){
System.out.println(i);
pw.write(buff,0,i);
}

read(char[] b,int off,int len) 和read(char[] b)的区别

标签:style   blog   io   ar   使用   sp   java   on   文件   

原文地址:http://blog.csdn.net/wj512416359/article/details/41923293

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!