为什么双打有 -0 和 +0?有什么背景和意义?
-0 (通常)被视为 0 *******.当 negative 浮点数非常接近于零以至于它可以被认为是 0 时,它可能会导致(要清楚,我指的是 )
用数学术语:
这说明了 0 和 -0 在计算意义上的一个显着区别.
这里有一些相关资源,其中一些已经提出.为了完整起见,我将它们包括在内:
Why do doubles have -0 as well as +0? What is the background and significance?
-0 is (generally) treated as 0 *******. It can result when a negative floating-point number is so close to zero that it can be considered 0 (to be clear, I'm referring to arithmetic underflow, and the results of the following computations are interpreted as being exactly ±0, not just really small numbers). e.g.
System.out.println(-1 / Float.POSITIVE_INFINITY);
-0.0
If we consider the same case with a positive number, we will receive our good old 0:
System.out.println(1 / Float.POSITIVE_INFINITY);
0.0
******* Here's a case where using -0.0 results in something different than when using 0.0:
System.out.println(1 / 0.0);
System.out.println(1 / -0.0);
Infinity -Infinity
This makes sense if we consider the function 1 / x. As x approaches 0 from the +-side, we should get positive infinity, but as it approaches from the --side, we should get negative infinity. The graph of the function should make this clear:
(source)
In math-terms:
This illustrates one significant difference between 0 and -0 in the computational sense.
Here are some relevant resources, some of which have been brought up already. I've included them for the sake of completeness:
这篇关于为什么浮点数有符号零?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!
如何在 JTextPane 中的组件周围环绕文本?How to wrap text around components in a JTextPane?(如何在 JTextPane 中的组件周围环绕文本?)
MyBatis,如何获取插入的自动生成密钥?[MySql]MyBatis, how to get the auto generated key of an insert? [MySql](MyBatis,如何获取插入的自动生成密钥?[MySql])
在 Java 中插入 Oracle 嵌套表Inserting to Oracle Nested Table in Java(在 Java 中插入 Oracle 嵌套表)
Java:如何将 CLOB 插入 oracle 数据库Java: How to insert CLOB into oracle database(Java:如何将 CLOB 插入 oracle 数据库)
为什么 Spring-data-jdbc 不保存我的 Car 对象?Why does Spring-data-jdbc not save my Car object?(为什么 Spring-data-jdbc 不保存我的 Car 对象?)
使用线程逐块处理文件Use threading to process file chunk by chunk(使用线程逐块处理文件)