当前位置:网站首页>十六进制文本的字节序问题

十六进制文本的字节序问题

2022-08-02 18:42:00 字母数字或汉字

给定一个十六进制字符串,要将其转换为 uint64,即使是使用语言自带的类库,也可能遇到暗含的字节序问题。

import sysdef foo(s):	b = bytearray.fromhex(s)	return int.from_bytes(b, sys.byteorder)def bar(s):	return int(s, 16)h = '0000000000000001'print(foo(h), bar(h)) # (72057594037927936, 1)

对应的 C# 代码是

private static UInt64 foo(string s) {	var b = Convert.FromHexString(s);	return BitConverter.ToUInt64(b);}private static UInt64 bar(string s) {	return Convert.ToUInt64(s, 16);}

这些语言类库都做了一个假设,当我们直接把字符串 0001 作为十六进制转换成十进制时,是按“大端序”来解析的,其结果在小端序的机器上的字节顺序是 01 00

0001 是一个字节数组时,其字节顺序被固定为 00 01,因此再将其按位直译成数字(不做解析),在小端序上就表示数字 0x00 + 0x01*256 == 256

当然,语言类库也都提供了各种参数/方法来逆字节序:

b = bytearray.fromhex(s)# b.reverse() # 逆字节序return int.from_bytes(b, 'big') # 假设本机是 little,逆一次字节序
var b = Convert.FromHexString(s);// Array.Reverse(b); // 逆字节序return BitConverter.ToUInt64(b);// return BinaryPrimitives.ReverseEndianness(x); // 逆字节序
原网站

版权声明
本文为[字母数字或汉字]所创,转载请带上原文链接,感谢
https://my.oschina.net/tridays/blog/5553892