概述
1是由于浮点数在转化为二进制时无法运算完结,所以会无限循环下去,如https://blog.csdn.net/luoqinglong850102/article/details/80526253,1.14,转化为二进制,然后再转回十进制就变成了1.1399999999999999023003738329862244427204132080078125。加减乘除运算就会出现失真,如:
package com.haobi.util;
import java.math.BigDecimal;
public class Test {
public static void main(String[] args) {
testdivide();
System.out.println("---------------");
testMultiply();
}
public static void testdivide(){
String aString = "1.14";
double b = Double.valueOf(aString);
System.out.println("double相除,精度丢失:"+b/10D);
System.out.println("double相除,精度丢失:"+new BigDecimal(Double.valueOf("1.14")).divide(new BigDecimal(10)));
System.out.println("string相除,精度正确:"+new BigDecimal("1.14").divide(new BigDecimal("10")));
}
public static void testMultiply(){
String aString = "1.14";
double b = Double.valueOf(aString);
BigDecimal bigDecimal = new BigDecimal(b);
int c = bigDecimal.multiply(new BigDecimal(100)).intValue();
System.out.println("b:"+b);
System.out.println("BigDecimal,精度丢失:"+bigDecimal);
System.out.println("double和int相乘,精度丢失:"+b*100);
System.out.println("bigdouble和bigint相乘,精度丢失:"+c);
System.out.println("bigString和bigint相乘,精度正确:"+new BigDecimal(aString).multiply(new BigDecimal(100)));
System.out.println("bigString和bigString相乘,精度正确:"+multiply(b,100).intValue()+"");
}
/***
* 两个数相乘
* @param param1
* @param param2
* @return
*/
public static BigDecimal multiply(Object param1,Object param2){
if(param1==null||"".equals(param1.toString())){
param1 = "0";
}
if(param2==null||"".equals(param2.toString())){
param2 = "0";
}
try {
return new BigDecimal(param1.toString()).multiply(new BigDecimal(param2.toString()));
} catch (Exception e) {
return BigDecimal.ZERO;
}
}
}
解决方法是使用jre提供的类BigDecimal,进行加减乘除运算,而且一定要使用字符串的构造方法,如:new BigDecimal(“1.14”)。不能使用数值类型,如:new BigDecimal(1.14)。
再有float和double的精度:https://blog.csdn.net/tianmd_Eric/article/details/79729827
最后
以上就是专注帆布鞋为你收集整理的java 小数精度问题的全部内容,希望文章能够帮你解决java 小数精度问题所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复