以下陈述不应该成立吗?
assertTrue(Double.isNaN(Math.tan(Math.acos(0d))));
但不是Double.NaN
Java返回
6.123233995736766 * 10^-17
在我的64位盒子上。
修改
这是一个复制和粘贴错误。事实上,Java返回1.633123935319537E16
我知道这是因为浮点表示,但我的印象是切线函数的那些未定义值将得到与例如相同的处理。 Math.sqrt(-1d)
但我想在这种情况下java.lang.Math只是在评估之前检查参数是否为正。
答案 0 :(得分:3)
我得到了不同的东西。
System.out.println(Math.tan(Math.acos(0d)));
// and the tan for the next representable value.
System.out.println(Math.tan(Math.acos(0d) + Math.ulp(Math.acos(0d))));
打印
1.633123935319537E16
-6.218431163823738E15
64位浮点不能完全表示PI / 2(它具有无穷多个数字),它表示接近此值的数字,并且该值的tan()是有限的。