python------位运算

位运算:
& 按位与     #都是1结果为1,只有一个1结果为0
| 按位或     #有1结果就为1
^ 按位异或   #不同为1,相同为0,如00011101^10011010 结果10000111
~ 按位取反   #
<<按位左移   #左移一位--------相当于乘2
>>按位右移   #右移一位--------相当于除2
作用:直接操作二进制,省内存,效率高
取反是对补码进行操作:如 ~9=-10
步骤:9的原码=反码=补码
0000 1001  
1.对补码取反得下
1111  0110
2.再将补码转化为原码
规则:符号位不变,其他位取反,再加1
1000 1001 #变成了负数
再+11000  1010 ==== -10
所以~9=-10

PS:补码求原码
(1)如果补码的符号位为“0”,表示是一个正数,所以补码就是该数的原码。
(2)如果补码的符号位为“1”,表示是一个负数,求原码的操作可以是:符号位为1,其余各位取反,然后再整个数加1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值