位运算符
# >> 无符号右移
# 0000 1010
# 0000 0010
# 0000 0101
result = 10 >> 2
result = 10 >> 1
# << 无符号左移
result = 10 << 1
result = 10 << 2
# 0001 0100
# 0000 1010
# 0000 0111
# 0000 0010
# & 按位与运算,两位都是1 返回1,否则返回0
result = 10 & 7
# | 按位或运算,两位有1就返回1,没有返回0
# 0000 1010
# 0000 0111
# 0000 1111
result = 10 | 7
# ^ 异或运算,如果两个数不一样,返回1,一样返回0
# 0000 1010
# 0000 0111
# 0000 1101
result = 10 ^ 7
# ~ 按位取反
# 0000 1010
# 1111 0101
result = ~10
print(result)
补码
# 1
# # 0000 0001
# # -1
# # 1000 0001
# # 在内存中存储一个数字时,最高位是符号位,如果最高位是0 就是正数,最高位是1就是负数
# # 1 - 1 => 1 + -1 = 0
# # 0000 0001
# # 1000 0001
# # 负数在计算机中参数运算时,不是直接运算的,他需要转换为补码,然后再运算
# # 反码 ,各位取反
# # 原码 1000 0001
# # 反码 0111 1110 + 1
# # 补码 0111 1111
#
# # 0000 0001
# # 0111 1111
# # 1000 0000 => -0
#
# # 1000 1010
# # 1111 0110 (-10的补码)
#
# -1 符号位不变,各位取反 + 1
# 1000 0001 原码
# 1111 1111 补码
# 0000 0001
# 1000 1010
# 1111 0110 补码
# 1111 1101 补码
# 1111 1100
# 1000 0011
# 求补码的过程
# 补码 = 反码 + 1
# 反码,符号位不变,其余各位取反
result = -10 >> 2
print(result)