位运算总结

位运算:
&(与):两个2进制数按位置取。都是1返回1。
应用:提取标志位,n1&n1mark(标志位为1其余为0的二进制数)!=0。如果为true说明n1的标志位
为1,为false说明n1的标志位为0。
|(或):两个2进制数按位置取。存在1返回1。
应用:标志位置1,n1 = n1|n1mark(标志位为1其余为0的二进制数),
^(异或):两个2进制数按位置取。两个数不同返回1。(异或符合交换律,结合律。自己异或自己
=0,任何数异或0等于本身)
应用:交换两个数
a=a^b;
b=a^b;
a=a^b;
拆解:假设
a1=a^b,
b1=a1b=ab^b=a,
a2=a1b1=ab^a=b
~(取反):对于一个数做转换,0->1 1->0。应用标志位置0:n1 = n1 & ~n1mark(标志位为1其余为0的二进制数)
<<左移运算符
正数:二进制数集体向左移动一位,末位补0。(*2)
负数:二进制数集体向左移动一位,末位补0。(负数左移不考虑符号位,所以移动后可能
为正数)
>>右移运算符
正数:二进制数集体向右移动一位,首位补0。(/2)
负数:二进制数集体向左移动一位,首位补1。(依旧是负数)
>>>无符号右移运算符
正数:二进制数集体向右移动一位,首位补0。(/2)
负数:二进制数集体向左移动一位,首位补0。(由负数变成正数)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值