在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
上面所述的两种方法适用于所有数学运算,在此以加法做为例子,作了简单的介绍。
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
上面所述的两种方法适用于所有数学运算,在此以加法做为例子,作了简单的介绍。
相关文章推荐
- 在java中ACCESS模糊查询出现的奇怪问题,使用%不行的解决方案。
- java集合经常出现空指针问题的解决方案
- 在java编程调试中出现的一些问题和解决方案
- Java非正常卸载出现的问题及解决方案
- 1202530 - Error: "HTTP Status 500"" when attempting to log on to Java InfoView using Active Directory(配置BOSSO出现的问题解决方案)
- 关于js语法(运算中出现无限大的问题)本身的错误的解决方案
- redis(三)--Java代码-telnet可以连接成功但是出现Connect timeout问题-解决方案
- double 类型运算时出现的问题及解决方案
- java执行jar出现编码问题的解决方案,Could not decode a text frame as UTF-8
- 【leetcode】【Single Number题目】java 异或运算解决数字出现偶数次还是奇数次问题||HashMap
- android java double 进行运算时,经常出现精度丢失的问题
- 关于Myeclipse出现 java文件中文乱码问题的解决方案.
- 关于AES256算法java端加密,ios端解密出现无法解密问题的解决方案
- 关于Java设置环境变量后的调试出现问题的解决方案
- 关于Java中用Double型运算时精度丢失的问题,真的很蛋疼!
- 【转】关于AES256算法java端加密,ios端解密出现无法解密问题的解决方案
- JAVA中float类型运算出现精度缺失,对于保留小数位解决方案
- java学习日记_57:Scanner获取数据出现的小问题及解决方案
- DT升级中出现的问题的解决方案(Android upgrade ADT 22, R.java files not generated,java.lang.ClassNotFoundException)