位运算的操作对象是整数类型,在运算过程中,整数被看作二进制的集合,位运算的功能是提供检查和设置二进制的功能。位运算遵从左结合律。
~(位求反),<<(左移),>>(右移),&(位与),^(位异或),|(位或)。
(1)左移(<<):把二进制位向左移位,右侧插入0进行补位。
(2)右移(>>): 把二进制向右移位,如左侧对象是无符号位,则插入为0的二进制。若为带符号类型,插入符号位的副本或者为0的二进制,视具体情况而定(原来第一个操作数是正数,补0;若是负数,补1)。
(3)位取反(~):对二进制逐位取反。
注:位运算是对补码进行运算的。
例: 二进制 无符号a 10011011
对a左移8位:
00000000 00000000 10011011 00000000
对a右移3位:
00000000 00000000 00000000 00010011
1.取一段数据中的特定几位数,用左移,右移。
2.对某几位清零,可用与。清零位为0,
3.对某位置1,可用或。置1位为1
4.对某几位取反,用求反。
5.对某两个数进行交换,用异或。
void swap1(int& a, int& b)
{
a ^= b;
b ^= a;
a ^= b;
}
例:取某数据的高8位,低8位数据,并合并成新数据的举例,见https://blog.csdn.net/hanxiaoyong_/article/details/88775395