基础入门补充
位运算
print(bin(4)) # 0b100
print(bin(5)) # 0b101
print(bin(~4), ~4) # -0b101 -5 (~ 按位非/反)
print(bin(4 & 5), 4 & 5) # 0b100 4 (& 按位与)
print(bin(4 | 5), 4 | 5) # 0b101 5 (| 按位或)
print(bin(4 ^ 5), 4 ^ 5) # 0b1 1 (^ 按位异或)
print(bin(4 << 2), 4 << 2) # 0b10000 16 (左移)
print(bin(4 >> 2), 4 >> 2) # 0b1 1 (右移)
二进制有三种不同的表示形式:原码、反码和补码,计算机内部使用补码来表示。
- Python中
bin
一个负数(十进制表示),输出的是它的原码的二进制表示加上个负号,巨坑。 - Python中的整型是补码形式存储的。
- Python中整型是不限制长度的不会超范围溢出。
所以为了获得负数(十进制表示)的补码,需要手动将其和十六进制数0xffffffff
进行按位与操作,再交给bin()
进行输出,得到的才是负数的补码表示。
#其他运算符注意点:
- is, is not 对比的是两个变量的内存地址。
- ==, != 对比的是两个变量的值。
- 比较的两个变量,指向的都是地址不可变的类型(str等),那么is,is not 和 ==,!= 是完全等价的。
- 对比的两个变量,指向的是地址可变的类型(list,dict,tuple等),则两者是有区别的。
- 注意运算符优先级。
数据类型
#保留float有效数字
import decimal
from decimal import Decimal
decimal.getcontext().prec = 4
c = Decimal(1) / Decimal(3)
print(c)
# 使 1/3 保留 4 位,用 getcontext().prec 来调整精度,输出0.3333。
除了直接给变量赋值 True(1)
和 False(0)</