byte & 0xff char 转换

https://blog.csdn.net/lixingtao0520/article/details/75450883

 

版权声明:本文为博主原创文章,转载请注明作者与出处,http://blog.csdn.net/lixingtao0520 https://blog.csdn.net/lixingtao0520/article/details/75450883
     在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;
}

---------------------
作者:BiggerLee
来源:CSDN
原文:https://blog.csdn.net/lixingtao0520/article/details/75450883
版权声明:本文为博主原创文章,转载请附上博文链接!

 

 

https://blog.csdn.net/iblade/article/details/73289831

 

在MD5运算中 通常会把MD5(十六进制的byte[])转成HexString, 
会用到一个方法

 private static String bytesToHex1(byte[] md5Array) {
        StringBuilder strBuilder = new StringBuilder();
        for (int i = 0; i < md5Array.length; i++) {
            int temp = 0xff & md5Array[i];//TODO:此处为什么添加 0xff & ?
            String hexString = Integer.toHexString(temp);
            if (hexString.length() == 1) {//如果是十六进制的0f,默认只显示f,此时要补上0
                strBuilder.append("0").append(hexString);
            } else {
                strBuilder.append(hexString);
            }
        }
        return strBuilder.toString();
    }

又如此段代码:

 byte[] bs = digest.digest(origin.getBytes(Charset.forName(charsetName))) ;  

        for (int i = 0; i < bs.length; i++) {  
            int c = bs[i] & 0xFF ;
            if(c < 16){ 
                sb.append("0");  
            }  
            sb.append(Integer.toHexString(c)) ;  
        }  
        return sb.toString() ; 

反复出现byte & 0xff 到底在做什么?

举个简单的例子:

byte[] b = new byte[5];

b[0] = -12;

byte 8位二进制 = 1个字节 char 2个字节 short (2个字节) int(4个字节) long(8个字节) float (4个字节) double(8个字节)

计算机存储数据机制:正数存储的二进制原码,负数存储的是二进制的补码。 补码是负数的绝对值反码加1。

比如-12,-12 的绝对值原码是:0000 1100 取反: 1111 0011 加1: 1111 0100

byte –> int 就是由8位变 32 位 高24位全部补1: 1111 1111 1111 1111 1111 1111 1111 0100 ;

0xFF 是计算机十六进制的表示: 0x就是代表十六进制,A B C D E F 分别代表10 11 12 13 14 15 F就是15 一个F 代表4位二进制:可以看做 是 8 4 2 1。

0xFF的二进制表示就是:1111 1111。 高24位补0:0000 0000 0000 0000 0000 0000 1111 1111;

-12的补码与0xFF 进行与(&)操作 最后就是0000 0000 0000 0000 0000 0000 1111 0100

转换为十进制就是 244。

byte类型的数字要&0xff再赋值给int类型,其本质原因就是想保持二进制补码的一致性。

当byte要转化为int的时候,高的24位必然会补1,这样,其二进制补码其实已经不一致了,&0xff可以将高的24位置为0,低8位保持原样。这样做的目的就是为了保证二进制数据的一致性。

有人问为什么上面的式子中b[0]不是8位而是32位,因为当系统检测到byte可能会转化成int或者说byte与int类型进行运算的时候,就会将byte的内存空间高位补1(也就是按符号位补位)扩充到32位,再参与运算。
--------------------- 
作者:iblade 
来源:CSDN 
原文:https://blog.csdn.net/iblade/article/details/73289831 
版权声明:本文为博主原创文章,转载请附上博文链接!

 https://blog.csdn.net/u011080472/article/details/51280919

https://blog.csdn.net/zhaominpro/article/details/79602381

https://blog.csdn.net/xiaozhouchou/article/details/79086604

    public static void main(String[] args) {
         int i = 1;
         int k = 0;
         for(int j = 0;j<33;j++){
              i = i << 1;
             System.out.println(Integer.toBinaryString( i));
             System.out.println(i);
         }
         System.out.println(i);
    }




2
100
4
1000
8
10000
16
100000
32
1000000
64
10000000
128
100000000
256
1000000000
512
10000000000
1024
100000000000
2048
1000000000000
4096
10000000000000
8192
100000000000000
16384
1000000000000000
32768
10000000000000000
65536
100000000000000000
131072
1000000000000000000
262144
10000000000000000000
524288
100000000000000000000
1048576
1000000000000000000000
2097152
10000000000000000000000
4194304
100000000000000000000000
8388608
1000000000000000000000000
16777216
10000000000000000000000000
33554432
100000000000000000000000000
67108864
1000000000000000000000000000
134217728
10000000000000000000000000000
268435456
100000000000000000000000000000
536870912
1000000000000000000000000000000
1073741824
10000000000000000000000000000000
-2147483648
0
0
0
0

  

posted @ 2018-12-04 19:20  无天666  阅读(1788)  评论(0编辑  收藏  举报