java中byte转换int时为何与0xff进行与运算
这篇讲的是Java开发中一个具体但容易踩坑的技术点:将byte数组转换为十六进制字符串时,为何要对每个字节先进行与`0xFF`的按位与运算。 作者直接从代码出发,点出看似多余的`& 0xFF`操作,并设问为何不能简单地将byte强转为int。其核心原因在于Java中byte(8位)与int(32位)的位数差异,以及计算机采用补码表示负数。当一个负数byte(如`-1`,二进制补码为`11111111`)被扩展为int时,会进行符号位填充,得到`0xFFFFFFFF`,这显然不是我们期望的原始字节对应的无符号数值。 与`0xFF`(二进制低8位为1,高24位为0)进行与运算,正是为了清除扩展产生的高位比特,强制将结果限制在低8位内,从而确保得到的是字节的正确无符号值(如`255`)。文章通过复习补码知识和举例说明,清晰地阐释了这一操作的必要性,是理解Java基本数据类型转换细节的一个好示例。