定点数的移位运算(逻辑左移和算术左移)

定点数的移位运算

逻辑移位和算数移位

对于408考研的同学,先抛结论:

对于左移操作符,不区分逻辑左移和算数左移,统统要移动符号位!!!,只有右移才分逻辑右移和算数右移

即:左移不区分逻辑左移和算数左移

左移不区分逻辑左移和算数左移

左移不区分逻辑左移和算数左移 重要的事情说三遍!!!

这里是很多 408考生已经错的一处知识点,如果你是考研的学生看到这里,就可以退出了,记住这个结论就行。

下面我用代码给大家证明一下上述结论:

c语言代码演示:

注:环境为64位系统下的visual studio2019

#include<stdio.h>

int main() {
    // 选择一个有符号整数作为例子
    int value = -10; // 以-10为例

    // 逻辑左移
    int logicalLeftShiftedValue = (unsigned)value << 1;
    // 算术左移
    int arithmeticLeftShiftedValue = value << 1;


    printf("原始值:%d\n", value);
    // 打印逻辑左移和算数左移的结果
    printf("算术左移结果:%d\n", arithmeticLeftShiftedValue);
    printf("逻辑左移结果:%d\n", logicalLeftShiftedValue);
    
    printf("-----------------------------------------------------\n");

    // 逻辑右移
    int logicalRightShiftedValue = (unsigned)value >> 1;
    // 算术右移
    int arithmeticRightShiftedValue = value >> 1;

    // 打印逻辑右移和算数右移的比较结果
    printf("算术右移结果:%d\n", arithmeticRightShiftedValue);
    printf("逻辑右移结果:%d\n", logicalRightShiftedValue);

    return 0;
}

输出结果:

image-20240516131238149

过程分析:

  • 系统初始化:
    有趣的冷知识: 在debug模式下,编译软件默认会把 空间内未初始化的栈内存上的指针全部填成 0xcccccccc,由GBK编码按字符输出为(0xCCCC)

image-20240516132316715

  • 逻辑左移和算术左移:
    image-20240516133226500

    由补码的符号扩展可知(数值相等):
    ffff fff6 = f6 = 1111 0110;ffff ffec = ec = 1110 1100;
    符合定律

  • 同理可知右移:
    image-20240516133725697

总结:

image-20240516133821458

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值