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

	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时进行补位


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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值