根据以下网站:精确度与准确度。精度=规格紧密。准确性=正确性。不要将精确度与准确性混淆。 http://introcs.cs.princeton.edu/java/91float/
有人可以定义然后解释与java浮点数相关的精度和准确度之间的区别
答案 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位十进制数。这取决于输入的准确性和算法的数值稳定性,你得到的结果是多么准确。