位数少的转换成位数多的,直接赋值就好了,比如8位的整数24转换成32位还是24。
而位数多的转换成位数少的是截取低位那么多位数,比如32位的整数257,其二进制是1 0000 0001,转换成8位时,就截取后面的8位,即0000 0001,所以32位的整数257转换成8位的整数时等于1。
32位的整数a转换成16位整数b,b = a & 0xFFFF
32位的整数a转换成8位整数b,b = a & 0xFF
a = np.array([257])
b = a.astype(np.uint8)
b
>>array([1], dtype=uint8)
32位转8位的数值相当于a & 0xFF,这只是对32位整数做与运算,并没有改变其位数
>>array([1], dtype=int32)
本文详细解析了不同位数整数之间的转换方法,重点介绍了高位到低位转换时的截取原则,以及如何通过与运算实现32位整数到16位或8位整数的转换。
2447

被折叠的 条评论
为什么被折叠?



