IO流自定义字节流的缓冲区


IO流自定义字节流的缓冲区:

思路:BufferedInputStream类中read()方法的工作原理
1)先一个一个从字节流中读取字节,读取一定量(自定义)之后,存储在一个字节数组(缓冲区)(FileInputStream.read(byte[] b)),并获得存储数量(read方法的返回值)。
2)一个一个字节返回,返回一个,存储数量减1,然后指针往后移一位,准备取下一个。
3)如果存储数量为0 ,代表当前数组中所有数据已经全部取完,此时再来一次读取(read(byte[] b)),再获得此次存储数量。
4)如果存储数量(即read方法返回-1),代表读到文件末尾,返回-1。
因此,需要用到以下几个变量:
读取的字节数量,指向数组中准备取哪一个的指针,将要返回的字节变量。

自定义的read方法实现如下:
变量在外面定义

int count = 0,pos = 0; //count记录数组存放多少字节,pos记录当前指针的位置(准备取第几个)
public int read() throws IOException
{
	byte b; // 本次读取的字节
	if(count==0)
	{
		pos = 0;
		count = is.read(by);
		if(count<0)
			return -1;
		if(count>0)
		{
			b = by[pos];
			count--;
			pos++;
			return b&255;

		}
	}
	else if(count>0)
	{
		b = by[pos];
		count--;
		pos++;
		return b&0xff;
	}
	return -1;
}


16行和25行return  b&255或b&0xff原因:
因为is.read读取的是一个字节,或者字节数组,而一个字节是用8位二进制表示,即0000 0000---1111 1111,而1111 1111刚好就是int的-1。(-1就是+1的取反加1,0000 0001 取反 -> 1111 1110,加1 -> 1111 1111),如果文件开头第一个字节就是1111 1111,则返回的直接就是-1(方法返回类型为int),这样就被当做是读到文件末尾而导致读取结束。因此要与上255,即(00000000 00000000 00000000 11111111),这样的话,才保证原字节值没变,而且不被当做-1而导致读取结束。

 

你可能感兴趣的:(Java)