整数的溢出,当达到最大值时,将会溢出到起始点;当达到最小值时,将会从最大点开始往变小方向溢出。比如在
32
位的
int
中,当变量为
2147483648
时,得到的输出结果是
-2147483648
。因为起始顺序是从
-2147483648
到
2147483647
。
浮点数上溢时,被赋予一个无穷大的值,
printf
函数显示的是
inf
。
浮点数下溢时,指数部分已经达到最小值,计算机只好将尾数部分进行右移,空出首位的二进制数,丢弃最后一位的二进制数。以十进制为例,把一个4位有效数字的数(如,0.1234E-10)除以10,得到的结果是0.123E-10.虽然得到了结果,但是在计算过程中却损失了原本尾有效位上的数字。这种情况叫做下溢(underflow)。C语言把损失了类型全精度的浮点值称为低于正常的浮点值。因此,把最小的正浮点数除以2将得到一个低于正常的值。如果除以一个非常大的值,会导致所有位都为0
。