永发信息网

java double数据类型运算问题

答案:4  悬赏:60  手机版
解决时间 2021-04-02 01:40
java double数据类型运算问题
最佳答案
使用Java,double 进行运算时,经常出现精度丢失的问题,总是在一个正确的结果左右偏0.0000**1。
特别在实际项目中,通过一个公式校验该值是否大于0,如果大于0我们会做一件事情,小于0我们又处理其他事情。
这样的情况通过double计算出来的结果去和0比较大小,尤其是有小数点的时候,经常会因为精度丢失而导致程序处理流程出错。
所以一般对double类型进行运算时,做好对结果进行处理,然后拿这个值去做其他事情。

目前总结如下:



public static double round(double value, int scale,

int roundingMode) {

BigDecimal bd = new BigDecimal(value);

bd = bd.setScale(scale, roundingMode);

double d = bd.doubleValue();

bd = null;

return d;

}


public double sum(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.add(bd2).doubleValue();
}


public double sub(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.subtract(bd2).doubleValue();
}


public double mul(double d1,double d2){
BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.multiply(bd2).doubleValue();
}


public double div(double d1,double d2,int scale){
// 当然在此之前,你要判断分母是否为0,

// 为0你可以根据实际需求做相应的处理

BigDecimal bd1 = new BigDecimal(Double.toString(d1));
BigDecimal bd2 = new BigDecimal(Double.toString(d2));
return bd1.divide

(bd2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();
}

这样,计算double类型的数据计算问题就可以处理了。
另外补充一下 JavaScript 四舍五入的方法:
小数点问题

Math.round(totalAmount*100)/100 (保留 2 位)

function formatFloat(src, pos)
{
return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
}
全部回答
浮点数值没办法用十进制来精确表示的原因要归咎于CPU表示浮点数的方法。这样的话您就可能会牺牲一些精度,有些浮点数运算也会引入误差。以上面提到的情况为例,2.4的二进制表示并非就是精确的2.4。反而最为接近的二进制表示是 2.3999999999999999。原因在于浮点数由两部分组成:指数和尾数。浮点数的值实际上是由一个特定的数学公式计算得到的。您所遇到的精度损失会在任何操作系统和编程环境中遇到。float类型的变量只有7位的精度,而double类型的变量有15位的精度
使用Java,double 进行运算时,经常出现精度丢失的问题,总是在一个正确的结果左右偏0.0000**1。 特别在实际项目中,通过一个公式校验该值是否大于0,如果大于0我们会做一件事情,小于0我们又处理其他事情。 这样的情况通过double计算出来的结果去和0比较大小,尤其是有小数点的时候,经常会因为精度丢失而导致程序处理流程出错。
解决方法有:
//方法一
NumberFormat nFormat=NumberFormat.getNumberInstance();
nFormat.setMaximumFractionDigits(2);//设置小数点后面位数为
System.out.println(nFormat.format(3.1415););
这个就是double的精度问题啊?
java.math.BigDecimal

double n=0.01;
double m=0.06;
java.math.BigDecimal d1=new java.math.BigDecimal(String.valueOf(n));
java.math.BigDecimal d2=new java.math.BigDecimal(String.valueOf(m));

System.out.println(d1.add(d2).doubleValue());
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
汽车急刹车时乘客都会往前亲那是因为物体的什
长夜慢慢兮,吾将上下而求所向是什么意思意思
12月9日是什么星座?
做五子棋JAVA所需要的知识点
吧里真的没人了吗?大家难道真的
有没有使用蓝灯专业版的?
求类似于《帅老公是高中生》的小说
歌词高潮是飘啊飘啊飘啊飘~~~是什么歌曲?
俞灏明和杨幂恋爱过吗 曾经相恋究竟是真是假
如图是壮壮同学的妈妈在超市买回来的蔬菜,用
中国移动吉祥号码预存一万,每月最低消费1000
哪里可以免费看睡在我上铺的兄弟电视剧?
求个网站,最好有动漫的。有毒不要,谢谢!
歌词我是一个怎样的女人,对你来说。。。求歌
亲子早教:感统失调怎么办
推荐资讯
轴承型号7314ACM.ACM表示什么
中超烧钱震惊全球 投入那么多钱中超仍没
学《三字经》有何重要意义?
黑界知名,北初QQ多少?
头发油性太重,控油洗发精也没效果,求解决
电脑音量太大会不会烧耳机
各种料位计的优、缺点
今年浦东新区有多少中考考生?
用邻苯二甲酸氢钾标定氢氧化钠的原理是啥?能
真诚问候传递温暖的广播稿
儿子17岁叛逆严重仇恨父母有自残现象怎么办
那年花开月正圆沈星移娘是谁演的
正方形一边上任一点到这个正方形两条对角线的
阴历怎么看 ?