位运算的操作对象是整数类型,在运算过程中,整数被看作二进制的集合,位运算的功能是提供检查和设置二进制的功能。位运算遵从结合律。
~(位求反),<<(左移),>>(右移),&(位与),^(位异或),|(位或)。
(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.对某两个数进行交换,用异或。
例:交换a,b值。
void swap1(int& a, int& b)
{
a ^= b;
b ^= a;
a ^= b;
}
例:取某数据的高8位,低8位数据,并合并成新数据的举例,见https://blog.csdn.net/hanxiaoyong_/article/details/88775395
C/C++获取unsigned short的高八位和低八位数值
#include "pch.h"
#include <iostream>
#include <string>
typedef unsigned char BYTE;
typedef unsigned short WORD;
typedef unsigned int UINT32;
using namespace std;
int main()
{
string s ;
char str[100] = "hello,worl------------------------------d" ;
WORD word = 0x1234;
BYTE b1 =(BYTE) (word &0xff );//低八位
BYTE b2 = (BYTE)(word << 8);//低八位
BYTE b3 = (BYTE)(word >> 8);//高八位
cout << "b1=" <<hex<< b1+0 << endl;
cout << "b2=" <<hex<< b2+0 << endl;
cout << "b3=" << hex << b3 + 0 << endl;
getchar();
return 0;
}
运行截图:
将WORD强制类型转换为BYTE,默认取BYTE低八位的数值作为BYTE的值
0x1234&0xff 是0x0034 取低八位 所以b1是0x34
0x1234<<8 左移8位 是0x3400 取低八位 所以b2是0x00,即0
0x1245>>8,右移8位 是0x0012 取低8位 所以b3是0x12
将占用长度大的类型强制转换为长度较小的类型,默认取低位值作为长度较小的类型的值
补充:(循环移位)
循环左移n位: (x>>(N - n) ) | (x<<n);
循环右移n位: (x<<(N - n) ) | (x>>n)。
cout << "b1=" << (int)b1 << endl;//这样输出,不+0
#include <bitset>
cout << "b3="<<bitset<sizeof(int)*8>(b3)<< endl;//二进制输出