目录
- C/C++ 左移<<, 右移>>作用
 - 1. 左移 <<
 - 2. 右移 >>
 - 3. 数字 1 左移 <<
 - C++ 左移右移越界情况
 - 左移越界
 - 右移越界
 
C/C++ 左移<<, 右移>>作用
1. 左移 <<
取两个数字,左移第一个操作数的位,第二个操作数决定要移动的位置。换句话说,左移动一个整数 x 和一个整数 y ( x < < y ) 等于 x 乘以 2y
代码示例:
/* C++ Program to demonstrate use of left shift  
   operator */
#include<stdio.h> 
int main() 
{ 
    // a = 5(00000101), b = 9(00001001) 
    unsigned char a = 5, b = 9;  
  
    // The result is 00001010  
    printf("a<<1 = %d\n", a<<1); 
    
    // The result is 00010010  
    printf("b<<1 = %d\n", b<<1);   
    return 0; 
} 
输出结果:
a<<1 = 10
b<<1 = 18
2. 右移 >>
取两个数字,向右移动第一个操作数的位,第二个操作数决定移动的位置。同样地,右平移( x > > y )等于x除以 2y.
代码示例:
/* C++ Program to demonstrate use of right 
   shift operator */
#include<stdio.h> 
  
using namespace std; 
int main() 
{ 
    // a = 5(00000101), b = 9(00001001) 
    unsigned char a = 5, b = 9;  
  
    // The result is 00000010  
       
    printf("a>>1 = %d\n", a>>1); 
    
    // The result is 00000100 
    printf("b>>1 = %d\n", b>>1);   
    return 0; 
}
输出结果:
a>>1 = 2
b>>1 = 4
3. 数字 1 左移 <<
1 << i = 2i。它只适用于正数。
代码示例:
#include<stdio.h> 
int main() 
{  
   int i = 3;   
   printf("pow(2, %d) = %d\n", i, 1 << i); 
   i = 4;   
   printf("pow(2, %d) = %d\n", i, 1 << i); 
   return 0; 
}
输出结果:
pow(2, 3) = 8
pow(2, 4) = 16
注意事项:

C++ 左移右移越界情况
左移越界
- 一个32位的long,值为1,
 - 左移32位 = 1
 - 左移33位= 2
 - …
 - 左移64位= 1
 - 左移65位= 3
 
所以左移越界有点向循环左移,左移Index位–》相当于左移 Index%32位 ,当然%多少是根据变量类型来定的
int main() {
 
	long v[2] = {0,0};
	long u1 = 1;
	long u2 = (u1 <<33);
	v[1] |= (u1<<33);
	LOG(sizeof(long))
	cout << u1 <<"," <<u2<< "," << v[1]<< endl;
	std::cin.get();
}
输出:

右移越界
右移越界,移出去的位都会变成0
#include<iostream>
#include<vector>
#include<unordered_map>
using namespace std;
#define LOG(x) std::cout<<x<<std::endl;
 
int main() {
 
	long v[2] = {0,0};
	long u1 =3;
	long u2 = (u1 >>1);
	v[1] |= (u1>>1);
	LOG(sizeof(long))
	cout << u1 <<"," <<u2<< "," << v[1]<< endl;
	std::cin.get();
}
输出:

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
	声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
		
评论(0)