java 字节转为16进制字符的个人理解

来源:互联网 发布:java分割符 编辑:程序博客网 时间:2024/06/10 17:27
public static void printHexString(byte[] b) {for (int i = 0; i < b.length; i++) {int temp = b[i] & 0xFF;String hex = Integer.toHexString(temp);if (hex.length() == 1) {hex = '0' + hex;}System.out.print(hex.toUpperCase());}}



以上代码将字节转为十六进制字符,以下是个人理解:

0.上面思路是:byte转int再算出16进制字符;

1.一个字节需要二进制的8个位,一个整型需要二进制的32个位;

2.  十六进制的1位相当于二进制的4个位;

3.  java的二进制是补码(第一位是符号,相对于原码,后面的位全部取反后+1);

4. 在二进制里,对于正数,原码,反码,补码表示都一样,但是,对于负数,原码,反码,补码表示各不同;

5. 不论是byte还是int,我们debug时看到的数值都是我们最常用的十进制数值;

上面是理论基础,下面是理解重点:

6. 对于负数,当byte直接转为int时,在二进制里,8位扩为32位,会进行补位,补位的结果是:数值没变,但是转换成十六进制字符变了(2个十六进制位变成了8个)。

举例(注意第三点):十进制的-1,二进制8个位表示:11111111; 补位后,二进制32个位表示:11111111111111111111111111111111,数值没变,都是十进制的-1,但是换成16进制的位表示,就有:0xFF变为0xFFFFFFFF,出现了差错;

7.负数进行byte & 0xFF 运算后的整型, 结合第一点,假设byte的十进制数值是-1,在二进制里运算是11111111111111111111111111111111 & 00000000000000000000000011111111  ,运算方法是单个位进行与运算,得到结果是00000000000000000000000011111111,即把byte的高24位清零,留下低8位,结果是:byte的十进制数值被改变,但是转换成十六进制有0xFF------>0xFF,消除了差错;

8.十六进制字符长度为1时补零:byte转为16进制应该有16进制的两个位,当16进制数值<=9时进行补位


如以上理解有误,欢迎指正!