当前位置:网站首页>C语言整数取值范围-负数多1的问题

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

2022-06-22 03:16:00 春夜喜雨

(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)

原网站

版权声明
本文为[春夜喜雨]所创,转载请带上原文链接,感谢
https://chunyexiyu.blog.csdn.net/article/details/120049849