左移运算 :
按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。
右移运算:
是将一个二进制位的操作数按指定移动的位数向右移动,移出位被丢弃,左边移出的空位一律补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;
}