第06天C语言(05):左移右移

一、概念

/*
 左移 <<
     规律 : 左移 就是左移的数乘以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;
}

推荐阅读更多精彩内容