Java基本类型与类型转换(2)——位操作: byte & 0xff

  • Post author:
  • Post category:java


在Java中 byte型数据在内存中占8位,int型数据在内存中占32位。0xff默认为int型,是十六进制,十进制中表示为255,二进制为32位,后八位为’1111 1111’,其他24位均为0;在&运算时,2个bit均为1,则得1,否则得0。

先看以下程序

         byte a = -17;
         System.out.println(a);
         System.out.println((int) a);
         System.out.println(a & 0xff);
         System.out.println(Integer.toBinaryString((int) a));
         System.out.println(Integer.toBinaryString(a & 0xff));
 
运行程序输出以下结果:



说明

:

1、a是byte型时,二进制表示为11101111;即-17(byte型);
2、a在强制转化为int型时,值仍为-17,转换规则:如果是负数,则高位补1,如果是正数,则高位补0。所以,a的值仍为-17(int型),二进制表示形式为’11111111111111111111111111101111’。
3、a & 0xff 操作时,因为a为byte型,所以会将a自动转化为int型(高位补1),再与0xff进行&操作,返回的数值二进制表示为’00000000000000000000000011101111’(toBinaryString方法省略了左边的0),此数值为239(int型)。
4、byte & 0xff操作一般将byte数据转换成int型,最终的数据只有低8位有数据,其他位为0。
5、Java中byte型转换为int型有两种:一种是保持数值不变,例如进行数值计算时,此时可采用强制类型转换,int b = (int) a ;另外一种是最低字节中各个位不变,高位用0填充,此时需要采用位操作 int b = a & 0xff,例如在编解码时,以及BufferedInputStream中的read方法。
 public synchronized int read() throws IOException {
        if (pos >= count) {
            fill();
            if (pos >= count)
                return -1;
        }
        return getBufIfOpen()[pos++] & 0xff;
    }



版权声明:本文为lixingtao0520原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。