声明:摘自其他人的博客, 总之唯一同一目的就是共享,共同进步,再就是给自己留个备份
float:浮点型,含字节数为4,32bit,数值范围为-3.4E38~3.4E38(7个有效位)
double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)
decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)
float f = 345.98756f;//结果显示为345.9876,只显示7个有效位,对最后一位数四舍五入。
double d=345.975423578631442d;//结果显示为345.975423578631,只显示15个有效位,对最后一位四舍五入。
注:float和double的相乘操作,数字溢出不会报错,会有精度的损失。
decimal dd=345.545454879.....//可以支持28位,对最后一位四舍五入。
注:当对decimal类型进行操作时,数值会因溢出而报错
double:双精度实型,含字节数为8,64bit数值范围-1.7E308~1.7E308(15个有效位)
decimal:数字型,128bit,不存在精度损失,常用于银行帐目计算。(28个有效位)
float f = 345.98756f;//结果显示为345.9876,只显示7个有效位,对最后一位数四舍五入。
double d=345.975423578631442d;//结果显示为345.975423578631,只显示15个有效位,对最后一位四舍五入。
注:float和double的相乘操作,数字溢出不会报错,会有精度的损失。
decimal dd=345.545454879.....//可以支持28位,对最后一位四舍五入。
注:当对decimal类型进行操作时,数值会因溢出而报错
public static void main(String[] args) {
// TODO Auto-generated method stub
//int m =123456789;
double a =123456789.678;
System.out.println(a);
System.out.println(BigDecimal.valueOf(a));
}
结果
1.23456789678E8
123456789.678
Begdicimal 无法进行+ *等运算,使用函数 add() multiply()
本文详细介绍了float、double及decimal三种浮点数类型的字节数、有效位数及其适用场景。并通过实例展示了不同类型的精度差异及操作注意事项。
1万+

被折叠的 条评论
为什么被折叠?



