我们有下面的测试代码:
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
时间: 2024-12-19 10:24:48