C语言整数取值范围-负数多1的问题

62 篇文章 0 订阅
33 篇文章 0 订阅

(Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu)

整数范围上,负数是多一个的,不知道大家是否好奇?

以单字节作为讨论点,探讨一下:

BYTE/char型取值范围是:[-128, +127],为什么是-128,为什么不也是-127?

围绕这个问题探讨:

我们已知BYTE/char型的话是8位的,最高位是符号位,那么就剩余7位了;

7位能表达什么,从0b0000000 到 0b1111111,可以表达0-127的范围;

符号位为0时,表达正数,0-127的范围正好就表达了;

符号位为1时,表达负数,0-127的范围,来表达-0到-127吗?0这个数字已经被正0表达了,那-0怎么办呢?也来表达0吗?

有了这个问题点,就需要解决这个问题点,-0 到-127的范围,实际取值个数是128种取值,如果全映射给负数,确实也就映射到了-1到-128的范围上了;作为按位计算消耗的C语言,不会浪费这个1/256个取值机会的。

选取映射算法,就算到补码头上来了,物理上最小值0b10000000也就是-0来表达-128,物理上的最大值0b11111111来表达最小值-1,映射过程就产生了。

同样的short范围/int范围/int64范围的情况皆是如此,这样也就解决了+0/-0的表达尴尬。

同时造就了在c/c++/java/c#这些语言种,整形变量的范围,负数范围大于正数范围一个值。因为采用了补码映射,从而物理上的-0被映射到了负数范围上的极限值。

(Owed by: 春夜喜雨 http://blog.csdn.net/chunyexiyu)

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

春夜喜雨

稀罕你的喜欢!!

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

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

打赏作者

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

抵扣说明:

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

余额充值