Java中精確的浮點運(yùn)算操作示例
本文實例講述了Java中精確的浮點運(yùn)算操作。分享給大家供大家參考,具體如下:
Java中浮點運(yùn)算對于很多值浮點數(shù)都是采用其能夠表示的離目標(biāo)值最近的數(shù)來表示,這有可能會在計算中帶來不易覺察的誤差。
如下所例:
public class ssss { public static void main(String[] ages){ double d1=2.07; double d2=1.03; System.out.println(d1+d2); } }
結(jié)果:
雖然計算結(jié)果離精確值誤差很小,但其不是精確的!這在像如金融計算一樣計算精確度要求很高的領(lǐng)域是無法接受的,但這是二進(jìn)制本身的問題,而計算機(jī)普遍采用二進(jìn)制表示,使用基本數(shù)據(jù)類型無法解決。
為了解決基本數(shù)據(jù)類型浮點數(shù)不能進(jìn)行精確計算的問題,Java中專門提供了java.math.BigDecimal類,其提供浮點數(shù)的精確計算功能。與BigInteger類相同,其運(yùn)算操作均使用方法調(diào)用完成
demo
public class ssss { public static void main(String[] ages){ BigDecimal b1=new BigDecimal("2.07"); BigDecimal b2=new BigDecimal("1.03"); System.out.println("相加運(yùn)算:"); System.out.println("b1:"+b1); System.out.println("b2:"+b2); System.out.println("相加值:"+b1.add(b2)); } }
輸出值:
其余函數(shù)參造下表
BigDecimal abs()
返回 BigDecimal,其值為此 BigDecimal 的絕對值,其標(biāo)度為 this.scale()。
BigDecimal abs(MathContext mc)
返回其值為此 BigDecimal 絕對值的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal add(BigDecimal augend)
返回一個 BigDecimal,其值為 (this + augend),其標(biāo)度為 max(this.scale(), augend.scale())。
BigDecimal add(BigDecimal augend, MathContext mc)
返回其值為 (this + augend) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
byte byteValueExact()
將此 BigDecimal 轉(zhuǎn)換為 byte,以檢查丟失的信息。
int compareTo(BigDecimal val)
將此 BigDecimal 與指定的 BigDecimal 比較。
BigDecimal divide(BigDecimal divisor)
返回一個 BigDecimal,其值為 (this / divisor),其首選標(biāo)度為 (this.scale() - divisor.scale());如果無法表示準(zhǔn)確的商值(因為它有無窮的十進(jìn)制擴(kuò)展),則拋出 ArithmeticException。
BigDecimal divide(BigDecimal divisor, int roundingMode)
返回一個 BigDecimal,其值為 (this / divisor),其標(biāo)度為 this.scale()。
BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
返回一個 BigDecimal,其值為 (this / divisor),其標(biāo)度為指定標(biāo)度。
BigDecimal divide(BigDecimal divisor, int scale, RoundingMode roundingMode)
返回一個 BigDecimal,其值為 (this / divisor),其標(biāo)度為指定標(biāo)度。
BigDecimal divide(BigDecimal divisor, MathContext mc)
返回其值為 (this / divisor) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal divide(BigDecimal divisor, RoundingMode roundingMode)
返回一個 BigDecimal,其值為 (this / divisor),其標(biāo)度為 this.scale()。
BigDecimal[] divideAndRemainder(BigDecimal divisor)
返回由兩個元素組成的 BigDecimal 數(shù)組,該數(shù)組包含 divideToIntegralValue 的結(jié)果,后跟對兩個操作數(shù)計算所得到的 remainder。
BigDecimal[] divideAndRemainder(BigDecimal divisor, MathContext mc)
返回由兩個元素組成的 BigDecimal 數(shù)組,該數(shù)組包含 divideToIntegralValue 的結(jié)果,后跟根據(jù)上下文設(shè)置對兩個操作數(shù)進(jìn)行舍入計算所得到的 remainder 的結(jié)果。
BigDecimal divideToIntegralValue(BigDecimal divisor)
返回 BigDecimal,其值為向下舍入所得商值 (this / divisor) 的整數(shù)部分。
BigDecimal divideToIntegralValue(BigDecimal divisor, MathContext mc)
返回 BigDecimal,其值為 (this / divisor) 的整數(shù)部分。
double doubleValue()
將此 BigDecimal 轉(zhuǎn)換為 double。
boolean equals(Object x)
比較此 BigDecimal 與指定的 Object 的相等性。
float floatValue()
將此 BigDecimal 轉(zhuǎn)換為 float。
int hashCode()
返回此 BigDecimal 的哈希碼。
int intValue()
將此 BigDecimal 轉(zhuǎn)換為 int。
int intValueExact()
將此 BigDecimal 轉(zhuǎn)換為 int,以檢查丟失的信息。
long longValue()
將此 BigDecimal 轉(zhuǎn)換為 long。
long longValueExact()
將此 BigDecimal 轉(zhuǎn)換為 long,以檢查丟失的信息。
BigDecimal max(BigDecimal val)
返回此 BigDecimal 和 val 的最大值。
BigDecimal min(BigDecimal val)
返回此 BigDecimal 和 val 的最小值。
BigDecimal movePointLeft(int n)
返回一個 BigDecimal,它等效于將該值的小數(shù)點向左移動 n 位。
BigDecimal movePointRight(int n)
返回一個 BigDecimal,它等效于將該值的小數(shù)點向右移動 n 位。
BigDecimal multiply(BigDecimal multiplicand)
返回一個 BigDecimal,其值為 (this × multiplicand),其標(biāo)度為 (this.scale() + multiplicand.scale())。
BigDecimal multiply(BigDecimal multiplicand, MathContext mc)
返回其值為 (this × multiplicand) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal negate()
返回 BigDecimal,其值為 (-this),其標(biāo)度為 this.scale()。
BigDecimal negate(MathContext mc)
返回其值為 (-this) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal plus()
返回 BigDecimal,其值為 (+this),其標(biāo)度為 this.scale()。
BigDecimal plus(MathContext mc)
返回其值為 (+this) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal pow(int n)
返回其值為 (thisn) 的 BigDecimal,準(zhǔn)確計算該冪,使其具有無限精度。
BigDecimal pow(int n, MathContext mc)
返回其值為 (thisn) 的 BigDecimal。
int precision()
返回此 BigDecimal 的精度。
BigDecimal remainder(BigDecimal divisor)
返回其值為 (this % divisor) 的 BigDecimal。
BigDecimal remainder(BigDecimal divisor, MathContext mc)
返回其值為 (this % divisor) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigDecimal round(MathContext mc)
返回根據(jù) MathContext 設(shè)置進(jìn)行舍入后的 BigDecimal。
int scale()
返回此 BigDecimal 的標(biāo)度。
BigDecimal scaleByPowerOfTen(int n)
返回其數(shù)值等于 (this * 10n) 的 BigDecimal。
BigDecimal setScale(int newScale)
返回一個 BigDecimal,其標(biāo)度為指定值,其值在數(shù)值上等于此 BigDecimal 的值。
BigDecimal setScale(int newScale, int roundingMode)
返回一個 BigDecimal,其標(biāo)度為指定值,其非標(biāo)度值通過此 BigDecimal 的非標(biāo)度值乘以或除以十的適當(dāng)次冪來確定,以維護(hù)其總值。
BigDecimal setScale(int newScale, RoundingMode roundingMode)
返回 BigDecimal,其標(biāo)度為指定值,其非標(biāo)度值通過此 BigDecimal 的非標(biāo)度值乘以或除以十的適當(dāng)次冪來確定,以維護(hù)其總值。
short shortValueExact()
將此 BigDecimal 轉(zhuǎn)換為 short,以檢查丟失的信息。
int signum()
返回此 BigDecimal 的正負(fù)號函數(shù)。
BigDecimal stripTrailingZeros()
返回數(shù)值上等于此小數(shù),但從該表示形式移除所有尾部零的 BigDecimal。
BigDecimal subtract(BigDecimal subtrahend)
返回一個 BigDecimal,其值為 (this - subtrahend),其標(biāo)度為 max(this.scale(), subtrahend.scale())。
BigDecimal subtract(BigDecimal subtrahend, MathContext mc)
返回其值為 (this - subtrahend) 的 BigDecimal(根據(jù)上下文設(shè)置進(jìn)行舍入)。
BigInteger toBigInteger()
將此 BigDecimal 轉(zhuǎn)換為 BigInteger。
BigInteger toBigIntegerExact()
將此 BigDecimal 轉(zhuǎn)換為 BigInteger,以檢查丟失的信息。
String toEngineeringString()
返回此 BigDecimal 的字符串表示形式,需要指數(shù)時,則使用工程計數(shù)法。
String toPlainString()
返回不帶指數(shù)字段的此 BigDecimal 的字符串表示形式。
String toString()
返回此 BigDecimal 的字符串表示形式,如果需要指數(shù),則使用科學(xué)記數(shù)法。
BigDecimal ulp()
返回此 BigDecimal 的 ulp(最后一位的單位)的大小。
BigInteger unscaledValue()
返回其值為此 BigDecimal 的非標(biāo)度值 的 BigInteger。
static BigDecimal valueOf(double val)
使用 Double.toString(double) 方法提供的 double 規(guī)范的字符串表示形式將 double 轉(zhuǎn)換為 BigDecimal。
static BigDecimal valueOf(long val)
將 long 值轉(zhuǎn)換為具有零標(biāo)度的 BigDecimal。
static BigDecimal valueOf(long unscaledVal, int scale)
將 long 非標(biāo)度值和 int 標(biāo)度轉(zhuǎn)換為 BigDecimal。
更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)學(xué)運(yùn)算技巧總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java字符與字符串操作技巧總結(jié)》、《java日期與時間操作技巧匯總》、《Java操作DOM節(jié)點技巧總結(jié)》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
- Java中使用BigDecimal進(jìn)行浮點數(shù)運(yùn)算
- java大數(shù)乘法的簡單實現(xiàn) 浮點數(shù)乘法運(yùn)算
- JAVA浮點數(shù)計算精度損失底層原理與解決方案
- Java中浮點數(shù)精度問題的解決方法
- java實現(xiàn)浮點數(shù)轉(zhuǎn)人民幣的小例子
- Java中的浮點數(shù)分析
- Java常用數(shù)字工具類 大數(shù)乘法、加法、減法運(yùn)算(2)
- java實現(xiàn)隨機(jī)輸出300題四則運(yùn)算
- Java中使用BigDecimal進(jìn)行精確運(yùn)算
- 【Java】BigDecimal實現(xiàn)加減乘除運(yùn)算代碼
- java中double類型運(yùn)算結(jié)果異常的解決方法
相關(guān)文章
Kafka單節(jié)點偽分布式集群搭建實現(xiàn)過程詳解
這篇文章主要介紹了Kafka單節(jié)點偽分布式集群搭建實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-11-11SpringBoot實現(xiàn)WebSocket即時通訊的示例代碼
本文主要介紹了SpringBoot實現(xiàn)WebSocket即時通訊的示例代碼,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-04-04java,android,MD5加密算法的實現(xiàn)代碼(16位,32位)
下面小編就為大家?guī)硪黄猨ava,android,MD5加密算法的實現(xiàn)代碼(16位,32位)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-09-09深入理解java內(nèi)置鎖(synchronized)和顯式鎖(ReentrantLock)
這篇文章主要介紹了Java多線程之內(nèi)置鎖(synchronized)和顯式鎖(ReentrantLock)的深入理解新的和用法,具有一定參考價值,需要的朋友可以了解下。2017-11-11IDEA提示內(nèi)存不足 low memory的完美解決方法(親測好用)
這篇文章主要介紹了IDEA提示內(nèi)存不足 low memory的完美解決方法(親測好用),這里以IDEA2022版本為例,在IDE中 幫助(help)–>change memory setting(改變內(nèi)存設(shè)置),具體設(shè)置辦法文中給大家詳細(xì)講解,需要的朋友可以參考下2023-01-01