A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 尹兆国 中级黑马   /  2014-6-14 16:10  /  1163 人查看  /  3 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 尹兆国 于 2014-6-15 14:56 编辑
  1. import java.io.*;

  2. class MyBufferedInputStream
  3. {
  4.         private InputStream in;

  5.         private byte[] buf = new byte[1024*4];
  6.                
  7.         private int pos = 0,count = 0;
  8.         
  9.         MyBufferedInputStream(InputStream in)
  10.         {
  11.                 this.in = in;
  12.         }

  13.         //一次读一个字节,从缓冲区(字节数组)获取。
  14.         public int myRead()throws IOException
  15.         {
  16.                 //通过in对象读取硬盘上数据,并存储buf中。
  17.                 if(count==0)
  18.                 {
  19.                         count = in.read(buf);//读4K
  20.                         if(count<0)
  21.                                 return -1;
  22.                         pos = 0;
  23.                         byte b = buf[pos];//存1B

  24.                         count--;
  25.                         pos++;
  26.                         return b&255;//为避免-1的出现,将b提升到int型,再&255
  27.                 }
  28.                 else if(count>0)
  29.                 {
  30.                         byte b = buf[pos];

  31.                         count--;
  32.                         pos++;
  33.                         return b&0xff;
  34.                 }
  35.                 return -1;

  36.         }
  37.         public void myClose()throws IOException
  38.         {
  39.                 in.close();
  40.         }
  41. }


  42. /*
  43. 11111111-111111110000000000101001001010100101010010101001010


  44. byte: -1  --->  int : -1;
  45. 00000000 00000000 00000000 11111111  255

  46. 11111111 11111111 11111111 11111111


  47. 11111111  -->提升了一个int类型 那不还是-1吗?是-1的原因是因为在8个1前面补的是1导致的。
  48. 那么我只要在前面补0,即可以保留原字节数据不变,又可以避免-1的出现。
  49. 怎么补0呢?

  50. 11111111 11111111 11111111 11111111                        
  51. &00000000 00000000 00000000 11111111
  52. ------------------------------------
  53. 00000000 00000000 00000000 11111111

  54. 0000-0001
  55. 1111-1110
  56. 000000001
  57. 1111-1111  -1


  58. 结论:
  59. 字节流的读一个字节的read方法为什么返回值类型不是byte,而是int。
  60. 因为有可能会读到连续8个二进制1的情况,8个二进制1对应的十进制是-1.
  61. 那么就会数据还没有读完,就结束的情况。因为我们判断读取结束是通过结尾标记-1来确定的。
  62. 所以,为了避免这种情况将读到的字节进行int类型的提升。
  63. 并在保留原字节数据的情况前面了补了24个0,变成了int类型的数值。


  64. 而在写入数据时,只写该int类型数据的最低8位。


  65. */
复制代码
b&0xff,为什么是这个,而不是b&255
  (毕老师java基础 day19 MyBufferedInputStream.java)

3 个回复

倒序浏览
毕老师说的是b&0xff和b&255这俩种写法都是可以的吧

点评

哦 谢谢  发表于 2014-6-15 14:48
回复 使用道具 举报
16进制就是0xFF,可以转化
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马