一、概念
/*
左移 <<
规律 : 左移 就是左移的数乘以2的移动次幂
例如
9 << 1 = 9 * 2(1) = 18
9 << 2 = 9 * 2(2) = 36
注意点 :
由于左移运算,被移动的数 最高位会被抛开(移除),所以左移有可能会改变一个数的正负性
右移 >>
*/
二、代码
#include <stdio.h>
int main()
{
#pragma 1.左移 <<
/*
9 << 1 = ?
9 << 2 = ?
规律 : 左移 就是左移的数乘以2的移动次幂
例如
9 << 1 = 9 * 2(1) = 18
9 << 2 = 9 * 2(2) = 36
注意点 :
由于左移运算,被移动的数 最高位会被抛开(移除),所以左移有可能会改变一个数的正负性
0000 0000 0000 0000 0000 0000 0000 1001 // 用于对比
0000 0000 0000 0000 0000 0000 0000 10010 // 16 + 2 = 18
0000 0000 0000 0000 0000 0000 0000 100100 // 32 + 4 = 36
*/
printf("1.左移 << %i\n",9<<1);
#pragma 2.右移 >>
/*
9 >> 1 = ?
9 >> 2 = ?
规律 : 右移 就是右移的数除以2的移动次幂
9 >> 1 = 9 / 2(1) = 4;
9 >> 1 = 9 / 2(2) = 2;
0000 0000 0000 0000 0000 0000 0000 1001 // 用于对比
00000 0000 0000 0000 0000 0000 0000 0100 // 4
00000 0000 0000 0000 0000 0000 0000 0010 // 2
-9>>1
0000 0000 0000 0000 0000 0000 0000 0000 // 用于对比
1000 0000 0000 0000 0000 0000 0000 1001 // 原码
1111 1111 1111 1111 1111 1111 1111 0110 // 反码
1111 1111 1111 1111 1111 1111 1111 0111 // 补码(反码+1)
补码 右移 1位
11111 1111 1111 1111 1111 1111 1111 011 // 右移 1位
-00000 0000 0000 0000 0000 0000 0000 001 // 补码转反码 (-1)
----------------------------------------
11111 1111 1111 1111 1111 1111 1111 010 // 反码
10000 0000 0000 0000 0000 0000 0000 101 // (反码转原码) -5
注意 : 负数的左移右移 是补码在移动,因为负数都是以补码的形式存储在内存中的
应用场景 : 如果想让某一个数 乘以2的多少次幂,或者除以2的多少次幂,最高运算方式就是左移右移
*/
printf("2.右移 >> %i\n",9>>1);
printf("2.右移 >> %i\n",-9>>1);
return 0;
}