在C89中,floor()返回一个double.以下保证是否有效?
double d = floor(3.0 + 0.5); int x = (int) d; assert(x == 3);
我担心的是,在IEEE 754中,地板的结果可能并不完全可以表示.所以d得到类似2.99999,而x最终为2.
对于这个问题的答案是肯定的,int范围内的所有整数必须完全可以表示为双精度,而floor必须始终返回该精确表示的值.
如果浮点类型支持所需的尾数位,则所有整数都可以具有精确的浮点表示.由于double
尾数使用53位,因此它可以int
精确地存储所有32位.毕竟,您可以将值设置为尾数为零指数.