3 回答

德玛西亚99
TA贡献1770条经验 获得超3个赞
(1<<bits)如果最高位为1 ,则二进制补码会减去。以8位为例,这将得出127至-128的范围。
一个整数的二的补码的函数。
def twos_comp(val, bits):
"""compute the 2's complement of int value val"""
if (val & (1 << (bits - 1))) != 0: # if sign bit is set e.g., 8bit: 128-255
val = val - (1 << bits) # compute negative value
return val # return positive value as is
从二进制字符串开始特别容易...
binary_string = '1111' # or whatever... no '0b' prefix
out = twos_comp(int(binary_string,2), len(binary_string))
对我来说更有用的是从十六进制值开始(在此示例中为32位)...
hex_string = '0xFFFFFFFF' # or whatever... '0x' prefix doesn't matter
out = twos_comp(int(hex_string,16), 32)
添加回答
举报
0/150
提交
取消