In [135]: bin(23) Out[135]: ‘0b10111‘ In [136]: oct(23) Out[136]: ‘0o27‘ In [137]: hex(23) Out[137]: ‘0x17‘
In [146]: 0b10111 Out[146]: 23 In [147]: 0o27 Out[147]: 23 In [148]: 0x17 Out[148]: 23
In [149]: int(‘0b10111‘, 2) Out[149]: 23 In [150]: int(‘0o27‘, 8) Out[150]: 23 In [151]: int(‘0x17‘, 16) Out[151]: 23
各二进位全部左移n位,高位丢弃,低位补0
x << n 左移 x 的所有二进制位向左移动n位,移出位删掉,移进的位补零
【注意事项】
b.左移可能会改变一个数的正负性
各二进位全部右移n位,保持符号位不变
x >> n, x的所有二进制位向右移动n位,移出的位删掉,移进的位补符号位, 右移不会改变一个数的符号
【注意事项】
全1才1否则0 :只有对应的两个二进位均为1时,结果位才为1,否则为0
用6和3这个例子。不要用9 和13的例子
有1就1 只要对应的二个二进位有一个为1时,结果位就为1,否则为0
不同为1 当对应的二进位相异(不相同)时,结果为1,否则为0
~9 = -10
【为什么9取反变成了-10的说明】:
9的原码 ==> 0000 1001 因为正数的原码=反码=补码,所以在 真正存储的时候就是0000 1001
接下来进行对9的补码进行取反操作
进行取反==> 1111 0110 这就是对9 进行了取反之后的补码
既然已经知道了补码,那么接下来只要转换为 咱们人能识别的码型就可以,因此按照规则 ,把这个1111 0110 这个补码 转换为原码即可
符号位不变,其它位取反==> 1000 1001
参考文献:
原文:https://www.cnblogs.com/nxf-rabbit75/p/10291792.html