java中钱一般用什么类型_为什么在java中涉及到钱的计算,我推荐用BigDecimal,而不是double和float...

在java中,用什么类型处理小数,一般下意识会想到float和double。

首先,为什么是这两个呢?

1.好用,单词写起来简单,记也好记,拼读发音也不容易错。

float  f = 1.1f;

double d = 1.2f;

2.四折运算(加减乘除)简单

float f1 = 1.2f;

float f2 = 1.3f;

float f3 = f2 - f1;

System.out.println(f3); //0.099999905

double d1 = 1.2f;

double d2 = 1.3f;

double d3= d2 - d1;

System.out.println(f3); //0.09999990463256836

再来看看BigDecimail,首先名字忒长,接着看看用法。

BigDecimail b1= new BigDecimail("1.2");

BigDecimail b1= new BigDecimail("1.3");  //怕写错,直接复制上面的,只将2改成了3,为什么这里1.3 变成了“1.3”?

//因为编译器二进制无法精确地表示十进制小数1.3,当它读到1.3时,会将1.3                                                                         //用8个字节的double值表示,可能你打印输出变成了                                                                                                                      //1.3000000000000000444089209850062616169452667236328125

BigDecimail b3 = b2.subtract(b1) ;//

b3.setScale(1,RoundingMode.HALF_UP);

System.out.println(b3);   //0.1

至此,应该看到了最大的问题吧。精度不一样,可能会造成很大的问题。1和0.99  都乘以1000  就相差了10,BigDecimail 可以有好几种定义精度的模式。而且值按道理是可以无限大的。由于BigDecimail性能肯定比不了int和long, 在小范围的值可以用int,long 来替换(*1000 之类的后面再除)。但是超过18位,就一定要用BigDecimail。当然咯,如果对值的精确要求不是特别高,还是可以使用float和double的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值