这篇文章主要介绍“C/C++左移<>的作用是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C/C++左移<>的作用是什么”文章能帮助大家解决问题。C/
这篇文章主要介绍“C/C++左移<<, 右移>>的作用是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C/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(); }
输出:
关于“C/C++左移<<, 右移>>的作用是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注恰卡网行业资讯频道,小编每天都会为大家更新不同的知识点。
本站部分文章来自网络或用户投稿,如无特殊说明或标注,均为本站原创发布。涉及资源下载的,本站旨在共享仅供大家学习与参考,如您想商用请获取官网版权,如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。