精度与精度java浮点数

时间:2017-01-22 07:51:02

标签: java

根据以下网站:精确度与准确度。精度=规格紧密。准确性=正确性。不要将精确度与准确性混淆。 http://introcs.cs.princeton.edu/java/91float/

有人可以定义然后解释与java浮点数相关的精度和准确度之间的区别

2 个答案:

答案 0 :(得分:3)

如果您查看IEEE 754的文档,则会介绍单个和双精度类型。它说"几乎所有硬件和编程语言都使用相同二进制格式的浮点数"。

通常的格式是总长度为32或64位:

  

格式:单精度

     

总比特数: 32

     

重要位: 23 + 1标志

     

指数位 8

     

最小数量: ca. 1.2⋅10(pow)-38

     

最大数量: ca. 3.4⋅10(pow)38

           

格式:双精度

     

总比特数: 64

     

重要位: 52 + 1符号

     

Exponent Bits: 11

     

最小数量: ca. 5.0⋅10(pow)-324

     

最大数量: ca. 5.0⋅10(pow)-324

Java遵循关键字支持的单精度和双精度类型。

float f = 0.1f; // 32 bit float, note f suffix

double d = 0.1d; // 64 bit float, suffix optional

如果在类,接口,方法上使用strictfp关键字,则会强制所有中间结果遵循 IEEE 754 值,并且保证相同的结果(准确性) )在所有平台上。如果没有strictfp关键字,实现可以使用可用的扩展指数范围,从而在许多常见CPU上产生更精确的结果和更快的执行。

因此,作为用户/程序员,可以指定精度(舍入值)。

示例:

String.format("%.2f", 3.2399) // returns "3.24"
String.format("%.3f", 3.2399) // returns "3.240"

精确度定义了计算或规范符合正确值或标准的程度。

有关详细信息,请查看Java SE Specifications

答案 1 :(得分:2)

精确度是您指定的位数,而精确度则指定与真实结果的差异。

举个例子:

3.14不如3.149精确,但如果被认为是pi的值则更准确。

Java float的精度约为6-7位十进制数。这取决于输入的准确性和算法的数值稳定性,你得到的结果是多么准确。