Java使用BigDecimal精確運(yùn)算浮點(diǎn)數(shù)
/**
* 進(jìn)行BigDecimal對(duì)象的加減乘除,四舍五入等運(yùn)算的工具類
*
* @author Marydon
* @createTime 2017年12月1日上午11:39:15
* @updateTime
* @Email:Marydon20170307@163.com
* @description 由于Java的簡(jiǎn)單類型不能夠精確的對(duì)浮點(diǎn)數(shù)進(jìn)行運(yùn)算,這個(gè)工具類提供了精確的浮點(diǎn)數(shù)運(yùn)算,包括加減乘除和四舍五入。
* @version:1.0.0
*/
public class ArithmeticUtiles {
/**
* 進(jìn)行BigDecimal對(duì)象的加減乘除,四舍五入等運(yùn)算的工具類
*
* @author wupenghui 由于Java的簡(jiǎn)單類型不能夠精確的對(duì)浮點(diǎn)數(shù)進(jìn)行運(yùn)算,這個(gè)工具類提供精 確的浮點(diǎn)數(shù)運(yùn)算,包括加減乘除和四舍五入。
*/
// 默認(rèn)除法運(yùn)算精度
private static final int DEF_DIV_SCALE = 10;
// 這個(gè)類不能實(shí)例化
private ArithmeticUtiles() {
}
/**
* 提供精確的加法運(yùn)算
*
* @param v1
* 被加數(shù)
* @param v2
* 加數(shù)
* @return 兩個(gè)參數(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();
}
/**
* 提供精確的減法運(yùn)算
*
* @param v1
* 被減數(shù)
* @param v2
* 減數(shù)
* @return 兩個(gè)參數(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();
}
/**
* 提供精確的乘法運(yùn)算
*
* @param v1
* 被乘數(shù)
* @param v2
* 乘數(shù)
* @return 兩個(gè)參數(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();
}
/**
* 提供(相對(duì))精確的除法運(yùn)算,當(dāng)發(fā)生除不盡的情況時(shí),精確到 小數(shù)點(diǎn)以后10位,以后的數(shù)字四舍五入
*
* @param v1
* 被除數(shù)
* @param v2
* 除數(shù)
* @return 兩個(gè)參數(shù)的商
*/
public static double div(double v1, double v2) {
return div(v1, v2, DEF_DIV_SCALE);
}
/**
* 提供(相對(duì))精確的除法運(yùn)算。當(dāng)發(fā)生除不盡的情況時(shí),由scale參數(shù)指定精度,以后的數(shù)字四舍五入。
*
* @param v1
* 被除數(shù)
* @param v2
* 除數(shù)
* @param scale
* 表示表示需要精確到小數(shù)點(diǎn)以后幾位。
* @return 兩個(gè)參數(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ù)點(diǎn)后保留幾位
* @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)不進(jìn)行四舍五入
*
* @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();
}
/**
* 返回兩個(gè)數(shù)中大的一個(gè)值
*
* @param v1
* 需要被對(duì)比的第一個(gè)數(shù)
* @param v2
* 需要被對(duì)比的第二個(gè)數(shù)
* @return 返回兩個(gè)數(shù)中大的一個(gè)值
*/
public static double returnMax(double v1, double v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.max(b2).doubleValue();
}
/**
* 返回兩個(gè)數(shù)中小的一個(gè)值
*
* @param v1
* 需要被對(duì)比的第一個(gè)數(shù)
* @param v2
* 需要被對(duì)比的第二個(gè)數(shù)
* @return 返回兩個(gè)數(shù)中小的一個(gè)值
*/
public static double returnMin(double v1, double v2) {
BigDecimal b1 = new BigDecimal(v1);
BigDecimal b2 = new BigDecimal(v2);
return b1.min(b2).doubleValue();
}
/**
* 精確對(duì)比兩個(gè)數(shù)字
*
* @param v1
* 需要被對(duì)比的第一個(gè)數(shù)
* @param v2
* 需要被對(duì)比的第二個(gè)數(shù)
*
* @return 如果兩個(gè)數(shù)一樣則返回0,如果第一個(gè)數(shù)比第二個(gè)數(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精確運(yùn)算浮點(diǎn)數(shù)的詳細(xì)內(nèi)容,更多關(guān)于Java 精確運(yùn)算浮點(diǎn)數(shù)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- 詳解java中BigDecimal精度問(wèn)題
- java 使用BigDecimal進(jìn)行貨幣金額計(jì)算的操作
- java中BigDecimal和0比較的示例代碼
- Java之BigDecimal實(shí)現(xiàn)詳解
- Java double轉(zhuǎn)BigDecimal的注意事項(xiàng)說(shuō)明
- Java用BigDecimal類解決Double類型精度丟失的問(wèn)題
- Java踩坑記錄之BigDecimal類
- 如何使用BigDecimal實(shí)現(xiàn)Java開(kāi)發(fā)商業(yè)計(jì)算
- 詳解Java中的BigDecimal
- Java BigDecimal使用及基本運(yùn)算(推薦)
- Java中BigDecimal類的使用詳解
- Java Bigdecimal使用原理詳解
- Java中BigDecimal類與int、Integer使用總結(jié)
- Java BigInteger類,BigDecimal類,Date類,DateFormat類及Calendar類用法示例
- 淺談Java基礎(chǔ)知識(shí)之BigDecimal
相關(guān)文章
實(shí)例講解String Date Calendar之間的轉(zhuǎn)換
下面小編就為大家?guī)?lái)一篇實(shí)例講解String Date Calendar之間的轉(zhuǎn)換。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07
hibernate 配置數(shù)據(jù)庫(kù)方言的實(shí)現(xiàn)方法
這篇文章主要介紹了hibernate 配置數(shù)據(jù)庫(kù)方言的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05
Java實(shí)現(xiàn)鼠標(biāo)拖拽移動(dòng)界面組件
在Java中,F(xiàn)rame或者JFrame自身已經(jīng)實(shí)現(xiàn)了鼠標(biāo)拖拽標(biāo)題欄移動(dòng)窗口的功能。但是Jframe的樣式實(shí)在無(wú)法令人滿意,那你又該怎么實(shí)現(xiàn)鼠標(biāo)拖拽移動(dòng)窗口的目的呢?今天我們來(lái)探討下2014-09-09
SpringBoot @Autowired注解注入規(guī)則介紹
這篇文章主要介紹了SpringBoot @Autowired注解注入規(guī)則介紹,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。2021-11-11
關(guān)于SpringBoot打包測(cè)試、生產(chǎn)環(huán)境方式
這篇文章主要介紹了關(guān)于SpringBoot打包測(cè)試、生產(chǎn)環(huán)境方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
J2SE基礎(chǔ)之下載eclipse并創(chuàng)建項(xiàng)目
本文給大家介紹的是最流行的java 集成開(kāi)發(fā)環(huán)境IDE eclipse的使用方法,非常的簡(jiǎn)單,有需要的小伙伴可以參考下2016-05-05

