python3 对 64 位的二进制进行异或的运算后,结果变成了 32 位的,这是什么逻辑?

2018-09-21 14:57:21 +08:00
 jiangjunhui4000
1888 次点击
所在节点    Python
4 条回复
simonliu2018
2018-09-21 16:42:38 +08:00
首先 python3 里应该没有 32 位、64 位整数,都叫整数:

In [169]: type(2 ** 64)
Out[169]: int

In [170]: type(2 ** 32)
Out[170]: int

另外,这个异或结果是 0,那是多少位的整数呢?

In [171]: (2 ** 64) ^ (2 ** 64)
Out[171]: 0
jiangjunhui4000
2018-09-21 17:19:58 +08:00
我指的是二进制的位数,如一下两个 64 位二进制
hash1 = '0b0010000110100001101101010101111110001001100001101011111110101000'
hash2 = '0b0010000110101001101101010101111110101001100001101011101110101000'

In [51]: bin(int(hash1,2)^int(hash2,2))
Out[51]: '0b1000000000000000000000100000000000000000010000000000' ##52 位

异或之后的位数不是 64 位了,不清楚中间的换算逻辑是怎样的
trueGate
2018-09-21 18:34:43 +08:00
@jiangjunhui4000 Python 没有位数的概念,只是省去了前面的 0 位,如果强制 64 位,可以用:`(bin(int(hash1,2)^int(hash2,2))[2:]).zfill(64)`
ysc3839
2018-09-21 18:36:44 +08:00
@jiangjunhui4000 因为转换为文本输出的时候会把开头的 0 省略掉。你自己补回去就好了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/491545

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX