首頁 >電腦教學 >電腦知識 >如何在JAVA中處理 double 精確度問題

如何在JAVA中處理 double 精確度問題

王林
王林轉載
2024-01-16 12:24:22981瀏覽

如何在JAVA中處理 double 精確度問題

JAVA怎麼解決double精確度問題。如1 2 3 3 599 996這種

public static double add(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.add(b2).doubleValue();

}

public static double sub(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.subtract(b2).doubleValue();

}

public static double mul(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.multiply(b2).doubleValue();

}

public static double div(double d1,double d2){

return div(d1,d2,DEF_DIV_SCALE);

}

public static double div(double d1,double d2,int scale){

//scale 是小數點後要保留的位數

if(scalethrow new IllegalArgumentException("精度不能小於零");

}

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();

}

用的時候呼叫這幾個方法。

java用double和float進行計算有時候精度不準確怎麼辦

在大多數情況下,使用double和float計算的結果是準確的,但是在一些精度要很高的系統中,這種問題是非常嚴重的。

在《Effective Java》中提到一個原則,那就是float和double只能用來做科學計算或是工程計算,但在商業計算中我們要用java.math.BigDecimal,透過使用BigDecimal類別可以解決上述問題,實例程式碼如下:

package ex;

import java.math.*;

public class BigDecimalDemo {

public static void main(String[] args){

System.out.println(ArithUtil.add(0.01, 0.05));

System.out.println(ArithUtil.sub(1.0, 0.42));

System.out.println(ArithUtil.mul(4.015, 100));

System.out.println(ArithUtil.div(123.3, 100));

}

}

class ArithUtil{

private static final int DEF_DIV_SCALE=10;

private ArithUtil(){}

//相加

public static double add(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.add(b2).doubleValue();

}

//相減

public static double sub(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.subtract(b2).doubleValue();

}

//相乘

public static double mul(double d1,double d2){

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.multiply(b2).doubleValue();

}

//相除

public static double div(double d1,double d2){

return div(d1,d2,DEF_DIV_SCALE);

}

public static double div(double d1,double d2,int scale){

if(scale

throw new IllegalArgumentException("The scale must be a positive integer or zero");

}

BigDecimal b1=new BigDecimal(Double.toString(d1));

BigDecimal b2=new BigDecimal(Double.toString(d2));

return b1.divide(b2,scale,BigDecimal.ROUND_HALF_UP).doubleValue();

}

}

Java關於double和int的問題

兩個int的值作除法運算,得到的為int,而且,得到的值是直接去掉小數部分。

假如:

int i=1;j=3;i/j==0 傳回的為true

同理,i/3==0 1/3==0 1/j==0都是回傳為true

如果,double res=i/j 其回傳的結果,不會是0.333...,而是0

如果你要得到0.333...,則需要 res=((double)i)/j;

而你的

fReuslt=(int)((double)num1/num2)

則會先執行num1/num2,如果num1和num2都int,都到的結果最終會是int,這裡假設num1=6,num2=5,則num1/num2==1 為true,而不是1.2 ,那麼,再執行(double)res,這裡的res就是num1/num2,故res=1,所以double之後還是為1,而不是1.2

以上是如何在JAVA中處理 double 精確度問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:docexcel.net。如有侵權,請聯絡admin@php.cn刪除