码迷,mamicode.com
首页 > 其他好文 > 详细

byte转换为十六进制时,Integer.toHexString需要&FF的原因

时间:2021-01-28 12:25:52      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:就是   ++   而在   alt   str   负数   cas   class   接收   

查看如下代码:
技术图片
        String mac_no_ff = "";
        for (int i = 0; i < 6; i++) {
            mac += Integer.toHexString(card[i] & 0xff).toUpperCase();
            mac_no_ff += Integer.toHexString(card[i]).toUpperCase();
        }
        System.out.println(mac);
        System.out.println(mac_no_ff);
技术图片

 

这个是输出
286ED488C8C3
286EFFFFFFD4FFFFFF88FFFFFFC8FFFFFFC3
 
28正常转换,
6E转换后多了一串FF
 
这是因为Integer.toHexString()的接收参数是int,不是byte,于是运算是会先把byte强制转换为int
由于java中强制转换是保持值不变,而在计算机中数都是用补码表示的,java中int是32位4个byte, 正数补码是正数本身,这样不会有问题,强转为32位时前面24位会填充0,
而负数的补码是"将其对应正数二进制表示所有位取反(包括符号位,0变1,1变0)后加1",
于是32位的0x00 00 00 80(0000 ... 0000 1000 0000)补码是0xFF FF FF 80(1111 ... 1111 1000 0000),前面是填充的1
所以Integer.toHexString()后就会变成前面多了一串F
所以要得到正确的结果,需要用 Integer.toHexString(card[i] & 0xff),这样会只取最后8位(1byte=8位二进制),前面都置0,这样转换出来就是正确的了.

byte转换为十六进制时,Integer.toHexString需要&FF的原因

标签:就是   ++   而在   alt   str   负数   cas   class   接收   

原文地址:https://www.cnblogs.com/king0207/p/14338322.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!