关于移位操作的一点说明
2016-04-07 19:48
239 查看
我们有下面的测试代码:
对于正数的移位操作:
7的二进制码为0111 当左移2位时(右边补0):11100 十进制28
当右移2位时(左边补0):001 十进制1
-7的二进制码1111 当左移两位时:111100(最高位为符号位) 十进制-28
当右移1位时 二进制码为1111 取反加一为补码 1001,再右移1位为0100 加上符号位为-4
当右移2位时 二进制码为1111 取反加一为补码 1001,再右移2位为0010 加上符号位为-2
1 #include <iostream> 2 using namespace std; 3 4 5 int main() 6 { 7 int num1=7; 8 cout<<"num1(7)<<2: "<<(num1<<2)<<endl; 9 cout<<"num1(7)>>2: "<<(num1>>2)<<endl; 10 int num2=-7; 11 cout<<"num2(-7)<<2: "<<(num2<<2)<<endl; 12 cout<<"num2(-7)>>1: "<<(num2>>1)<<endl; 13 cout<<"num2(-7)>>2: "<<(num2>>2)<<endl; 14 return 0; 15 }
对于正数的移位操作:
7的二进制码为0111 当左移2位时(右边补0):11100 十进制28
当右移2位时(左边补0):001 十进制1
-7的二进制码1111 当左移两位时:111100(最高位为符号位) 十进制-28
当右移1位时 二进制码为1111 取反加一为补码 1001,再右移1位为0100 加上符号位为-4
当右移2位时 二进制码为1111 取反加一为补码 1001,再右移2位为0010 加上符号位为-2
相关文章推荐
- [IO]——纯文本写出
- jrtt
- HDU 4289Control【最大流已知点权拆点】
- 拉灯游戏加强版
- 相机切换
- Win10驱动数字签名的解决办法
- Linux的mmap内存映射机制解析
- 线性回归模型
- spring MVC入门
- 14.linux按键驱动程序(一)
- 矩阵快速幂 UVA 10870 Recurrences
- WebView浏览本地html
- [IO]——纯文本读取
- Spark容错机制
- SecureCRT rz 上传文件失败问题
- CentOS7修改默认运行级别
- 平衡二叉树---Shaolin
- 《深入理解计算机系统》第七章读书笔记
- HttpRequest
- Android——列表视图 ListView(三)BaseAdapter