数值溢出问题

本文探讨了有符号数和无符号数在溢出时的行为,通过代码实例展示了当char类型变量超过其最大值时,如何导致数值变化。在有符号数中,溢出会改变数的正负;而对于无符号数,溢出则会导致最高位丢失。此外,解释了反码表示法,并指出了在8位二进制数中-128没有原码和反码的原因。
摘要由CSDN通过智能技术生成

前言

对于有符号数来说,符号位溢出会导致数的正负发生改变。
对于无符号数来说,最高位的溢出会导致最高位丢失。

代码实现

/*关于数值溢出*/

#include <stdio.h>

int main()
{
    char ch1;
    unsigned char ch2;

    ch1 = 0x7f + 2;    //-127
    ch2 = 0xff + 1;    //0

    printf("ch1 = %d,ch2 = %d\n",ch1,ch2);

    return 0;

}

程序运行结果

在这里插入图片描述

结果分析

char ch1 = 0x7f + 2;
转换成2进制
原码:0111_1111 + 2—>1000_0001
反码:1111_1110
补码:1111_1111 —> -127

unsigned char ch2 = 0xff + 1;
转换成2进制
原码:1111_1111 + 1—>0000_0000
反码:1111_1111
补码:0000_0000 —> 0

小知识

反码表示法规定:正数的反码与其原码相同。负数的反码是对其原码逐位取反,但符号位除外。
二.原码 反码 补码的范围
前提:字长是8位二进制数。
原码 -127~ 127 (-128没有原码反码,原因看后面解释~)
反码 -127~127
补码 -128~127

字长8位时-128没有原码和反码原因:
首先看-0,[-0]原码=1000 000,其中1是符号位,求反操作,算出[-0]反码=1111 1111,
再看-128,假如它有原码且[-128]原码=1000 000,假如让-128也有反码,求反操作,
则[-128]反码=1111 1111。
你会发现,-128的反码和-0的反码相同,所以为了避免面混淆,有了-0的原码,便不能有-128的原码补码,这是8位比特位位数限制决定的。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

⁽⁽ଘ晴空万里ଓ⁾⁾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值