Java使用BigDecimal精確運算浮點數(shù)
更新時間:2020年10月23日 14:56:38 作者:Marydon
這篇文章主要介紹了Java使用BigDecimal精確運算浮點數(shù),幫助大家更好的處理浮點數(shù)數(shù)據(jù),感興趣的朋友可以了解下
/**
* 進行BigDecimal對象的加減乘除,四舍五入等運算的工具類
*
* @author Marydon
* @createTime 2017年12月1日上午11:39:15
* @updateTime
* @Email:Marydon20170307@163.com
* @description 由于Java的簡單類型不能夠精確的對浮點數(shù)進行運算,這個工具類提供了精確的浮點數(shù)運算,包括加減乘除和四舍五入。
* @version:1.0.0
*/
public class ArithmeticUtiles {
/**
* 進行BigDecimal對象的加減乘除,四舍五入等運算的工具類
*
* @author wupenghui 由于Java的簡單類型不能夠精確的對浮點數(shù)進行運算,這個工具類提供精 確的浮點數(shù)運算,包括加減乘除和四舍五入。
*/
// 默認除法運算精度
private static final int DEF_DIV_SCALE = 10;
// 這個類不能實例化
private ArithmeticUtiles() {
}
/**
* 提供精確的加法運算
*
* @param v1
* 被加數(shù)
* @param v2
* 加數(shù)
* @return 兩個參數(shù)的和
*/
public static double add(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.add(b2).doubleValue();
}
/**
* 提供精確的減法運算
*
* @param v1
* 被減數(shù)
* @param v2
* 減數(shù)
* @return 兩個參數(shù)的差
*/
public static double sub(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.subtract(b2).doubleValue();
}
/**
* 提供精確的乘法運算
*
* @param v1
* 被乘數(shù)
* @param v2
* 乘數(shù)
* @return 兩個參數(shù)的積
*/
public static double mul(double v1, double v2) {
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.multiply(b2).doubleValue();
}
/**
* 提供(相對)精確的除法運算,當發(fā)生除不盡的情況時,精確到 小數(shù)點以后10位,以后的數(shù)字四舍五入
*
* @param v1
* 被除數(shù)
* @param v2
* 除數(shù)
* @return 兩個參數(shù)的商
*/
public static double div(double v1, double v2) {
return div(v1, v2, DEF_DIV_SCALE);
}
/**
* 提供(相對)精確的除法運算。當發(fā)生除不盡的情況時,由scale參數(shù)指定精度,以后的數(shù)字四舍五入。
*
* @param v1
* 被除數(shù)
* @param v2
* 除數(shù)
* @param scale
* 表示表示需要精確到小數(shù)點以后幾位。
* @return 兩個參數(shù)的商
*/
public static double div(double v1, double v2, int scale) {
if (scale < 0) {
throw new IllegalArgumentException("The scale must be a positive integer or zero");
}
BigDecimal b1 = new BigDecimal(Double.toString(v1));
BigDecimal b2 = new BigDecimal(Double.toString(v2));
return b1.divide(b2, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 提供精確的小數(shù)位四舍五入處理。
*
* @param v
* 需要四舍五入的數(shù)字
* @param scale
* 小數(shù)點后保留幾位
* @return 四舍五入后的結(jié)果
*/
public static double round(double v, int scale) {
if (scale < 0) {
throw new IllegalArgumentException("The scale must be a positive integer or zero");
}
BigDecimal b = new BigDecimal(Double.toString(v));
BigDecimal one = new BigDecimal("1");
return b.divide(one, scale, BigDecimal.ROUND_HALF_UP).doubleValue();
}
/**
* 提供精確的類型轉(zhuǎn)換(Float)
*
* @param v
* 需要被轉(zhuǎn)換的數(shù)字
* @return 返回轉(zhuǎn)換結(jié)果
*/
public static float convertsToFloat(double v) {
BigDecimal b = new BigDecimal(v);
return b.floatValue();
}
/**
* 提供精確的類型轉(zhuǎn)換(Int)不進行四舍五入
*
* @param v
* 需要被轉(zhuǎn)換的數(shù)字
* @return 返回轉(zhuǎn)換結(jié)果
*/
public static int convertsToInt(double v) {
BigDecimal b = new BigDecimal(v);
return b.intValue();
}
/**
* 提供精確的類型轉(zhuǎn)換(Long)
*
* @param v
* 需要被轉(zhuǎn)換的數(shù)字
* @return 返回轉(zhuǎn)換結(jié)果
*/
public static long convertsToLong(double v) {
BigDecimal b = new BigDecimal(v);
return b.longValue();
}
/**
* 返回兩個數(shù)中大的一個值
*
* @param v1
* 需要被對比的第一個數(shù)
* @param v2
* 需要被對比的第二個數(shù)
* @return 返回兩個數(shù)中大的一個值
*/
public static double returnMax(double v1, double v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.max(b2).doubleValue();
}
/**
* 返回兩個數(shù)中小的一個值
*
* @param v1
* 需要被對比的第一個數(shù)
* @param v2
* 需要被對比的第二個數(shù)
* @return 返回兩個數(shù)中小的一個值
*/
public static double returnMin(double v1, double v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.min(b2).doubleValue();
}
/**
* 精確對比兩個數(shù)字
*
* @param v1
* 需要被對比的第一個數(shù)
* @param v2
* 需要被對比的第二個數(shù)
*
* @return 如果兩個數(shù)一樣則返回0,如果第一個數(shù)比第二個數(shù)大則返回1,反之返回-1
*/
public static int compareTo(double v1, double v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.compareTo(b2);
}
}
以上就是Java使用BigDecimal精確運算浮點數(shù)的詳細內(nèi)容,更多關(guān)于Java 精確運算浮點數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!
您可能感興趣的文章:
- 詳解java中BigDecimal精度問題
- java 使用BigDecimal進行貨幣金額計算的操作
- java中BigDecimal和0比較的示例代碼
- Java之BigDecimal實現(xiàn)詳解
- Java double轉(zhuǎn)BigDecimal的注意事項說明
- Java用BigDecimal類解決Double類型精度丟失的問題
- Java踩坑記錄之BigDecimal類
- 如何使用BigDecimal實現(xiàn)Java開發(fā)商業(yè)計算
- 詳解Java中的BigDecimal
- Java BigDecimal使用及基本運算(推薦)
- Java中BigDecimal類的使用詳解
- Java Bigdecimal使用原理詳解
- Java中BigDecimal類與int、Integer使用總結(jié)
- Java BigInteger類,BigDecimal類,Date類,DateFormat類及Calendar類用法示例
- 淺談Java基礎(chǔ)知識之BigDecimal
相關(guān)文章
Java JDBC連接Kerberos認證的HIVE和Impala方式
本文主要介紹了HiveJDBC和ImpalaJDBC的使用方法,包括版本對應(yīng)、Maven安裝、主機名配置、端口開通、JDBC連接和Kerberos認證等2025-02-02
利用Jmeter發(fā)送Java請求的實戰(zhàn)記錄
JMeter是Apache組織的開放源代碼項目,它是功能和性能測試的工具,100%的用java實現(xiàn),下面這篇文章主要給大家介紹了關(guān)于如何利用Jmeter發(fā)送Java請求的相關(guān)資料,需要的朋友可以參考下2021-09-09
分布式調(diào)度XXL-Job整合Springboot2.X實戰(zhàn)操作過程(推薦)
這篇文章主要介紹了分布式調(diào)度XXL-Job整合Springboot2.X實戰(zhàn)操作,包括定時任務(wù)的使用場景和常見的定時任務(wù),通過本文學(xué)習(xí)幫助大家該選擇哪個分布式任務(wù)調(diào)度平臺,對此文感興趣的朋友一起看看吧2022-04-04
深入解析面向?qū)ο缶幊淘贘ava中的應(yīng)用小結(jié)
本文詳細介紹了面向?qū)ο缶幊痰幕靖拍?包括類和對象、封裝、繼承和多態(tài),通過具體的Java代碼示例,展示了如何在Java中應(yīng)用這些面向?qū)ο缶幊痰暮诵乃枷?感興趣的朋友跟隨小編一起看看吧2025-01-01

