一,为什么会溢出
每一种数据类型都有数值范围,这个数值范围体现在分配给数组的内存大小,每种数据类型的内存大小都是固定的,如果存放的数值超出了这个范围(小于最小值或大于最大值),需要更多的二进制位存储,就会发生溢出。
溢出的本质是数据二进制的长度超出了对应数据类型的内存大小。
更简单的说,内存装不下数据就会出现溢出。

大于最大值,叫做向上溢出(overflow);小于最小值,叫做向下溢出(underflow)。
二,如何处理溢出
编译器一般不会对溢出报错,会正常执行代码,但是会自作主张的把溢出的二进制位忽略,只保留剩下的位,这样往往会得到意想不到的结果。
就好比你的银行账户有一个亿,但系统把高位的1给抹掉了,余额瞬间变成0。

所以,在涉及数字运算时,一定要考虑溢出的情况。
下面示例中,变量x加1,得到的结果不是256,而是0。
unsigned char x = 255;
x = x + 1;
printf("%d\n", x); // 0
原因如下图,char类型在内存中只分配8位,最大值255的二


6435

被折叠的 条评论
为什么被折叠?



