在java中对double型运算出现的问题与解决方案

 
在许多应用开发中,很多时候都会涉及到金额数字的处理,但由于计算机运算是使用二进制代码进行相关的计算,所以在很多运算中都会出现误差,现以java语言为例作一些简单的介绍。
public class Test
{
       public static void main(String[] args)
       {
              double d=1.10+1.30+1.11;
              System.out.println(d);
       }
}
运行结果:3.5100000000000007
与我们所期望的值有所偏差,实际应得到的值应为3.51
 
解决方法:
<!--[if !supportLists]--> 1. <!--[endif]-->运用BigDecimal类解决运算时的误差
import java.math.BigDecimal;
public class Test
{
       public static void main(String[] args)
       {
              BigDecimal bd1=new BigDecimal("1.10");
              BigDecimal bd2=new BigDecimal("1.30");
              BigDecimal bd3=new BigDecimal("1.11");
              System.out.println(bd1.add(bd2).add(bd3).toString());
       }
}
运行结果:3.51
思考,如果把上面程序改为:
import java.math.BigDecimal;
public class Test
{
       public static void main(String[] args)
       {
              BigDecimal bd1=new BigDecimal(1.10);
              BigDecimal bd2=new BigDecimal(1.30);
              BigDecimal bd3=new BigDecimal(1.11);
              System.out.println(bd1.add(bd2).add(bd3).toString());
       }
}
测试看看,还是会出现误差!所以请区别来用。
解法2:
把小数化为整数,用int型进行计算,可以解决运算时出现的误差
由于金额的运算一般保留小数点后两位,故以此作为计算
 
public class Test
{
       public static String convertYangToFen(String yang)
       {
              String result="";
              int length=yang.length()-yang.indexOf(".");
              if(length>3||length<2||yang.indexOf(".")==-1)
                     return "";
              else if(length==2)
                     result = yang.replaceAll("//.","")+"0";
              else
                     result = yang.replaceAll("//.","");
              return result;
       }
      
       public static String convertFenToYuan(String money)
       {
              DecimalFormat decimalFormat = new DecimalFormat("00");
              return String.valueOf(Long.parseLong(money) / 100)
                            + "."
                            + decimalFormat.format(Long.parseLong(String.valueOf(Long
                                          .parseLong(money) % 100)));
       }
       public static void main(String[] args)
       {
              long money1=Long.parseLong(convertYangToFen ("1.10"));
              long money2=Long.parseLong(convertYangToFen ("1.30"));
              long money3=Long.parseLong(convertYangToFen ("1.11"));
              long result=money1+money2+money3;
              System.out.println(convertFenToYuan(String.valueOf(result)));
       }
 
}
运行结果:3.51
上面所述的两种方法适用于所有数学运算,在此以加法做为例子,作了简单的介绍。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值