C++位操作的常见用法小结

摘自:http://www.jb51.net/article/54824.htm

本文以实例形式对C++位操作的常见用法进行了总结。分享给大家供大家参考之用。具体方法如下:

在C++中位操作有6种基本操作符,按照优先级分别是:

取反   ~
移位   <<  >>
与      &
异或   ^
或      |

常用的用法有:

1 判断偶数,判断最低位是0还是1即可,比求模快

?
1
2
x % 2 != 0    //x正负都可以判断;不用x%2 == 1,因为如果x为负奇数,x%2=-1
x & 0x1 == 0

2 交换两个数,不用中间变量

?
1
2
3
4
5
6
7
8
9
void mySwap( int &a, int &b)
{
   if (a == b)  //相等时也能得到正确结果,但是没必要了
     return ;
 
   a ^= b;
   b ^= a;
   a ^= b;
}

3 求整数的二进制表示中1的个数,不用一个一个的移位判断

?
1
2
3
4
5
6
7
8
9
10
int numOfBit1( int a)
{
   int cnt = 0;
   while (a != 0)
   {
     ++cnt;
     a &= a - 1;  //将最右边的1置为0;正负都可计算,负数是按照补码计算的,最后的符号位也被统计
   }
   return cnt;
}

4 正负转换,不使用正负号。不管正数负数,取反后加1即可

?
1
2
3
int a = 1;
a = ~a + 1;  //a变成-1
a = ~a + 1;  //a又变成1

5 求绝对值,不判断正数负数,不使用正负号,返回绝对值

?
1
2
3
4
5
int myAbs( int a)
{
   int sign = a >> 31;    //如果a为正数,sign为0;否则sign为-1,即0xFFFFFFFF
   return (a^sign) - sign;  //(a^0)-0 = a, (a^-1)-(-1) = ~a+1 = -a ,a^-1即为a取反
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值