&0xff和MD5分别做什么?

&0xff和MD5分别做什么?,第1张

&0xff和MD5分别做什么?

大概大多数代码都是清晰的,这里唯一让您感到困惑的是此表达式:

(bytes[i] & 0xff) + 0x100

第一部分:

bytes[i] & 0xff

加宽位置字节

i
int
的比特位置8-31用零值。在Java中,
byte
数据类型是带符号的整数值,因此加宽的符号会扩展该值。如果没有
&0xff
,则大于0x7f的值最终将变为负值
int
。剩下的就很明显了:它添加了0x100,它只是打开了索引8的位(因为它保证为0 in
(bytes[i] & 0xff)
。然后
String
通过调用转换为十六进制值)
Integer.toString(..., 16)

首先添加0x100,然后剥离1(通过

substring(1)
调用完成,它将子字符串从位置1到末尾开始)的原因是为了保证最终结果中的两个十六进制数字。否则,转换为十六进制时,低于0x10的字节值将以一个字符的字符串结尾。

是否所有性能都比以下更好(尚不清楚)尚有争议:

sb.append(String.format("%02x", bytes[i]));


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5489909.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-12
下一篇2022-12-12

发表评论

登录后才能评论

评论列表(0条)

    保存