Python中为什么可以通过bin(n & 0xffffffff)来获得负数的补码?

一开始我以为这不是个大问题,因为本来整型数在内存中就是以补码的形式存在的,输出自然也是按照补码输出的,例如C语言中

printf("%X\n",-3);
//输出
//FFFFFFFD

但是我看了下Python的bin()的输出之后震惊了

a = bin(-3)
print(a)

a = bin(3)
print(a)

b = bin(-3 & 0xffffffff)
print(b)

c = bin(0xfffffffd)
print(c)

//输出
//-0b11
//0b11
//0b11111111111111111111111111111101
//0b11111111111111111111111111111101

也就是说

  1. Python中的整型是补码形式存储的
  2. Python中bin一个负数(十进制表示),输出的是它的原码的二进制表示加上个负号,方便查看(方便个鬼啊)
  3. Python中bin一个负数(十六进制表示),输出的是对应的二进制表示。(注意此时)

所以你为了获得负数(十进制表示)的补码,需要手动将其和十六进制数0xfffffffd进行按位与操作,得到结果也是个十六进制数,再交给bin()进行输出,得到的才是你想要的补码表示。

posted @ 2019-05-22 17:34  shengguorui  阅读(4632)  评论(0编辑  收藏  举报