您的位置:首页 > 编程语言 > Java开发

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

2007-06-30 23:33 423 查看
在许多应用开发中,很多时候都会涉及到金额数字的处理,但由于计算机运算是使用二进制代码进行相关的计算,所以在很多运算中都会出现误差,现以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
上面所述的两种方法适用于所有数学运算,在此以加法做为例子,作了简单的介绍。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐