何建锐

Java人生

  BlogJava :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  2 随笔 :: 0 文章 :: 0 评论 :: 0 Trackbacks

在许多应用开发中,很多时候都会涉及到金额数字的处理,但由于计算机运算是使用二进制代码进行相关的计算,所以在很多运算中都会出现误差,现以java语言为例作一些简单的介绍。

public Test

{

       public static void main(String[] args)

       {

              double d=1.10+1.30+1.11;

              System.out.println(d);

       }

}

运行结果:3.5100000000000007

与我们所期望的值有所偏差,实际应得到的值应为3.51

 

解决方法:

1.  运用BigDecimal类解决运算时的误差

import java.math.BigDecimal;

public 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 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 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

上面所述的两种方法适用于所有数学运算,在此以加法做为例子,作了简单的介绍。

posted on 2007-06-16 14:30 何建锐 阅读(588) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航: