今天在读取文件里的十六进制数据的时候,采用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); }
时间: 2025-01-02 15:59:29