视频里老师演示了in.read(byte[] by,int start,by.length)方法的两种形式。
1、在第一种方法里,
int bytes=in.read(buf,0,buf.length);
?这行命令被放在了外面,说明数组足够大,可以一次性读完
读到的字节数等于数组的长度,可能会出现两种情况,一种是数组足够大,读取的数据放不满数组,第二种情况是数组不够大,读取的数据数组放不完。
由于可能会出现这两种情况,所以循环条件我们不能用
for(int i=0;i<buf.length;i++)
第一种情况下,读取到的字符数<buf.length
第二种情况下,读取到的字符数>buf,length
2.在第二种方法里,
int bytes=in.read(buf,0,buf.length);
?这行命令被放到了while()里面变成了
while((int bytes=in.read(buf,0,buf.length))!=-1)
另外注意一下,我们以数组形式输出16进制数时,因为byte类型是8字节,int类型是32字节,为了避免数据转换错误我们最好通过&0xff的形式将高24位清0
如
System.out.print(Integer.toHexString(buf[i]&0xff)+" ");
(似乎是为了防止数组不够大放不下才用这种写法?不是很理解这两个方法间的区别,已经在课程下面提问了,等有人回答了再来编辑)