欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于BigDecimal.setScale的用法小結(jié)

 更新時間:2020年09月26日 16:02:50   作者:Wilson Tsai  
這篇文章主要介紹了基于BigDecimal.setScale的用法小結(jié),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1. BigDecimal num1 = new BigDecimal(2.225667);//這種寫法不允許,會造成精度損失

2. BigDecimal num2 = new BigDecimal(2);//這種寫法是可以的

3. BigDecimal num = new BigDecimal("2.225667");//一般都會這樣寫最好

4. int count = num.scale();

System.out.println(count);//6 返回的是小數(shù)點后位數(shù)

好了,下面開始正式介紹知識點啦~~~~~~

1. ROUND_DOWN

BigDecimal b = new BigDecimal("2.225667").setScale(2, BigDecimal.ROUND_DOWN);

System.out.println(b);//2.22 直接去掉多余的位數(shù)

2. ROUND_UP

BigDecimal c = new BigDecimal("2.224667").setScale(2, BigDecimal.ROUND_UP);

System.out.println(c);//2.23 跟上面相反,進位處理

3. ROUND_CEILING

天花板(向上),正數(shù)進位向上,負數(shù)舍位向上

BigDecimal f = new BigDecimal("2.224667").setScale(2, BigDecimal.ROUND_CEILING);
System.out.println(f);//2.23 如果是正數(shù),相當于BigDecimal.ROUND_UP
 
BigDecimal g = new BigDecimal("-2.225667").setScale(2, BigDecimal.ROUND_CEILING);
System.out.println(g);//-2.22 如果是負數(shù),相當于BigDecimal.ROUND_DOWN

4. ROUND_FLOOR

地板(向下),正數(shù)舍位向下,負數(shù)進位向下

BigDecimal h = new BigDecimal("2.225667").setScale(2, BigDecimal.ROUND_FLOOR);
System.out.println(h);//2.22 如果是正數(shù),相當于BigDecimal.ROUND_DOWN
 
BigDecimal i = new BigDecimal("-2.224667").setScale(2, BigDecimal.ROUND_FLOOR);
System.out.println(i);//-2.23 如果是負數(shù),相當于BigDecimal.ROUND_HALF_UP

5. ROUND_HALF_UP

BigDecimal d = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_UP);

System.out.println("ROUND_HALF_UP"+d); //2.23 四舍五入(若舍棄部分>=.5,就進位)

6. ROUND_HALF_DOWN

BigDecimal e = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_DOWN);

System.out.println("ROUND_HALF_DOWN"+e);//2.22 四舍五入(若舍棄部分>.5,就進位)

7. ROUND_HALF_EVEN

BigDecimal j = new BigDecimal("2.225").setScale(2, BigDecimal.ROUND_HALF_EVEN);
System.out.println(j);//2.22 如果舍棄部分左邊的數(shù)字為偶數(shù),則作  ROUND_HALF_DOWN 
 
BigDecimal k = new BigDecimal("2.215").setScale(2, BigDecimal.ROUND_HALF_EVEN);
System.out.println(k);//2.22 如果舍棄部分左邊的數(shù)字為奇數(shù),則作  ROUND_HALF_UP
 
 System.out.println("************************************");
 
 System.out.println("4.05: "+new BigDecimal("4.05").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.05: 4.0 down
 System.out.println("4.15: "+new BigDecimal("4.15").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.15: 4.2 up
 System.out.println("4.25: "+new BigDecimal("4.25").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.25: 4.2 down
 System.out.println("4.35: "+new BigDecimal("4.35").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.35: 4.4 up
 System.out.println("4.45: "+new BigDecimal("4.45").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.45: 4.4 down
 System.out.println("4.55: "+new BigDecimal("4.55").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.55: 4.6 up
 System.out.println("4.65: "+new BigDecimal("4.65").setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.65: 4.6 down
 
 System.out.println("3.05: "+new BigDecimal("3.05").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.05: 3.0 down
 System.out.println("3.15: "+new BigDecimal("3.15").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.15: 3.2 up
 System.out.println("3.25: "+new BigDecimal("3.25").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.25: 3.2 down
 System.out.println("3.35: "+new BigDecimal("3.35").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.35: 3.4 up
 System.out.println("3.45: "+new BigDecimal("3.45").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.45: 3.4 down
 System.out.println("3.55: "+new BigDecimal("3.55").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.55: 3.6 up
 System.out.println("3.65: "+new BigDecimal("3.65").setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.65: 3.6 down

8.ROUND_UNNECESSARY

BigDecimal l = new BigDecimal("2.215").setScale(3, BigDecimal.ROUND_UNNECESSARY);
System.out.println(l);
//斷言請求的操作具有精確的結(jié)果,因此不需要舍入。
//如果對獲得精確結(jié)果的操作指定此舍入模式,則拋出ArithmeticException。

補充知識:BigDecimal中divide方法注意問題

BigDecimal中divide方法拋異常:

Non-terminating decimal expansion; no exact representable decimal result

在使用

BigDecimal rate = new BigDecimal(1).divide(new BigDecimal(3));

時拋異常:

Non-terminating decimal expansion; no exact representable decimal result

原來是在做除法的時候出現(xiàn)了無限不循環(huán)小數(shù)如:0.333333333333

解決方案

在做做除法的時候指定保留的小數(shù)的位數(shù):

BigDecimal rate = new BigDecimal(1).divide(new BigDecimal(3), 6, BigDecimal.ROUND_HALF_UP);

以上這篇基于BigDecimal.setScale的用法小結(jié)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • java實現(xiàn)識別二維碼圖片功能

    java實現(xiàn)識別二維碼圖片功能

    這篇文章主要為大家詳細介紹了java實現(xiàn)識別二維碼圖片功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • SpringMVC 如何使用注解完成登錄攔截

    SpringMVC 如何使用注解完成登錄攔截

    這篇文章主要介紹了SpringMVC 如何使用注解完成登錄攔截,幫助大家更好的理解和學習使用springMVC,感興趣的朋友可以了解下
    2021-03-03
  • Spring5中的WebClient使用方法詳解

    Spring5中的WebClient使用方法詳解

    這篇文章主要給大家介紹了關于Spring5中WebClient使用方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Spring5具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-11-11
  • Java Swing JSlider滑塊的實現(xiàn)示例

    Java Swing JSlider滑塊的實現(xiàn)示例

    這篇文章主要介紹了Java Swing JSlider滑塊的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • JPA之QueryDSL-JPA使用指南

    JPA之QueryDSL-JPA使用指南

    Springdata-JPA是對JPA使用的封裝,Querydsl-JPA也是基于各種ORM之上的一個通用查詢框架,使用它的API類庫可以寫出Java代碼的sql,下面就來介紹一下JPA之QueryDSL-JPA使用指南
    2023-11-11
  • Java動態(tài)代理的應用詳解

    Java動態(tài)代理的應用詳解

    本篇文章介紹了,Java動態(tài)代理的應用詳解,需要的朋友參考下
    2013-05-05
  • java list去重操作實現(xiàn)方式

    java list去重操作實現(xiàn)方式

    Java中的List是可以包含重復元素的(hash code 和equals),接下來將介紹兩種方式實現(xiàn)java list去重操作,感興趣的朋友可以參考下
    2012-12-12
  • Java實現(xiàn)全圖背景水印的示例詳解

    Java實現(xiàn)全圖背景水印的示例詳解

    這篇文章主要為大家詳細介紹了如何利用Java實現(xiàn)全圖背景水印的方法,文中的示例代碼講解詳細,具有一定的借鑒價值,需要的可以參考一下
    2023-02-02
  • Java使用OSS實現(xiàn)上傳文件功能

    Java使用OSS實現(xiàn)上傳文件功能

    這篇文章主要為大家詳細介紹了Java如何使用OSS實現(xiàn)上傳文件功能,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以了解一下
    2024-01-01
  • MyBatis-Plus動態(tài)返回實體類示例詳解

    MyBatis-Plus動態(tài)返回實體類示例詳解

    這篇文章主要為大家介紹了MyBatis-Plus動態(tài)返回實體類示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07

最新評論