第一次看毕老师讲这个程序时我很蒙,思路跟不上,听的很迷糊,后来多看了几次,慢慢就懂了
首先我们看看这个程序的大体思路:
1、先把文件里的字节数据存到内存中的一个字节数组中去,
FileInputStream in = new FileInputStream("路径");
通过read(buf)把数据存到字节数组中去
count = in.read(buf); 这时候count是说把多少了字节存到了字节数组中去,比如存满了,存了1024个
2、把内存中的字节数组一个字节一个字节的送到缓冲区BufferedInputStream中去
先把第一次的字节数组送过去
byte b = buf[pos];
pos++,count--, 就是位置在+1,字节个数在--
知识补充:关于-1的补码问题,1111-1111,首先看它的最高位为1, 0正1负,表示这是一个负数,想要还原它也很简单,还是符号位不变,取反加1
在byte想int类型转换是,前面的3个字节扩充为全1,这个1是根据符号位扩充的,符号位是几就扩充,这些内容是我在计算机组成这门课上学到的,
有兴趣的朋友可以去看看唐朔飞写的这本书的第六章,里面有更为详细的介绍
还有点小知识,ff为什么是8个1,很简单,2的4次方=16, 4个1就等于1个f
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
class myBufferedinStream{
private InputStream in;
private int pos = 0,count = 0;
private byte buf[] = new byte[1024];
myBufferedinStream(InputStream in){
this.in = in;
}
public int myRead()throws IOException{
if(count==0)//第一组的字符数组取完了,第二组才能再取1024个
{
count = in.read(buf);//将读取的字节存到buf数组中,并返回字节数给count
if(count<0)
return -1;//说明已经取到了这一个数组的最后一个
pos = 0;//从数组的0位置开始读取
byte b = buf[pos];//获取内存中数组中的每一个元素
count--;
pos++;
return b&255;//&255,并且返回的是4字节的int型,但取了低8位,为了防止连续读到8个1,就是-1
}
else if(count>0)//要是第一组的字节数组还没取完,就接着取
{
byte b = buf[pos];
count--;
pos++;
return b&0xff;//十六进制也可以
}
return -1;
}
public void myClose() throws IOException{
in.close();
}
}