左移运算 :

按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。


右移运算:

是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位一律补0,或者补符号位。(这由不同的机器而定。在使用补码作为机器数的机器中,正数的符号位为0,负数的符号位为1。)

<<      :     左移运算符,n<< m  相当于n乘以2的m次方

>>      :     右移运算符,n >> m  相当于n除以2的m次方

(1)左移是逻辑/算术左移(两者完全相同),右移是算术右移,会保持符号位不变。
(2)实际应用中根据情况用左/右移做快速的乘/除运算,会比循环效率高很多。

#include<iostream>

using namespace std;

int main()
{
	//左移运算符 
	int a=3<<2;
	cout<<a<<endl;
	
	//右移运算符 
	int b=11>>2;
	cout<<b;
	return 0;
 }