整数和浮点数的溢出

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

你可能感兴趣的:(整数和浮点数的溢出)