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而导致读取结束。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哪知道

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值