JAVA中控制double和float的精度

本篇介紹了在JAVA中如何對double或者float的浮點數進行精度計算,在JAVA中提供了多種參數來實現精度的不同控制方式。具體例子如下: 

轉自http://stephen830.iteye.com/blog/260776

Java代碼 
  1. /* 
  2.  * Created on 2005-6-5 
  3.  * Author stephen 
  4.  * Email zhoujianqiang AT gmail DOT com 
  5.  * CopyRight(C)2005-2008 , All rights reserved. 
  6.  */  
  7. package com.soft4j.utility;  
  8.   
  9. import java.math.BigDecimal;  
  10.   
  11. /** 
  12.  * 與小數位精度(四捨五入等)相關的一些常用工具方法. 
  13.  *  
  14.  * float/double的精度取值方式分爲以下幾種: <br> 
  15.  * java.math.BigDecimal.ROUND_UP <br> 
  16.  * java.math.BigDecimal.ROUND_DOWN <br> 
  17.  * java.math.BigDecimal.ROUND_CEILING <br> 
  18.  * java.math.BigDecimal.ROUND_FLOOR <br> 
  19.  * java.math.BigDecimal.ROUND_HALF_UP<br> 
  20.  * java.math.BigDecimal.ROUND_HALF_DOWN <br> 
  21.  * java.math.BigDecimal.ROUND_HALF_EVEN <br> 
  22.  *  
  23.  * @author stephen 
  24.  * @version 1.0.0 
  25.  */  
  26. public final class RoundTool {  
  27.   
  28.     /** 
  29.      * 對double數據進行取精度. 
  30.      * <p> 
  31.      * For example: <br> 
  32.      * double value = 100.345678; <br> 
  33.      * double ret = round(value,4,BigDecimal.ROUND_HALF_UP); <br> 
  34.      * ret爲100.3457 <br> 
  35.      *  
  36.      * @param value 
  37.      *            double數據. 
  38.      * @param scale 
  39.      *            精度位數(保留的小數位數). 
  40.      * @param roundingMode 
  41.      *            精度取值方式. 
  42.      * @return 精度計算後的數據. 
  43.      */  
  44.     public static double round(double value, int scale, int roundingMode) {  
  45.         BigDecimal bd = new BigDecimal(value);  
  46.         bd = bd.setScale(scale, roundingMode);  
  47.         double d = bd.doubleValue();  
  48.         bd = null;  
  49.         return d;  
  50.     }  
  51.   
  52.     /** 
  53.      * 測試用的main方法. 
  54.      *  
  55.      * @param argc 
  56.      *            運行參數. 
  57.      */  
  58.     public static void main(String[] argc) {  
  59.         //下面都以保留2位小數爲例  
  60.           
  61.         //ROUND_UP  
  62.         //只要第2位後面存在大於0的小數,則第2位就+1  
  63.         System.out.println(round(12.3401,2,BigDecimal.ROUND_UP));//12.35  
  64.         System.out.println(round(-12.3401,2,BigDecimal.ROUND_UP));//-12.35  
  65.         //ROUND_DOWN  
  66.         //與ROUND_UP相反  
  67.         //直接捨棄第2位後面的所有小數  
  68.         System.out.println(round(12.349,2,BigDecimal.ROUND_DOWN));//12.34  
  69.         System.out.println(round(-12.349,2,BigDecimal.ROUND_DOWN));//-12.34  
  70.         //ROUND_CEILING  
  71.         //如果數字>0 則和ROUND_UP作用一樣  
  72.         //如果數字<0 則和ROUND_DOWN作用一樣  
  73.         System.out.println(round(12.3401,2,BigDecimal.ROUND_CEILING));//12.35  
  74.         System.out.println(round(-12.349,2,BigDecimal.ROUND_CEILING));//-12.34  
  75.         //ROUND_FLOOR  
  76.         //如果數字>0 則和ROUND_DOWN作用一樣  
  77.         //如果數字<0 則和ROUND_UP作用一樣  
  78.         System.out.println(round(12.349,2,BigDecimal.ROUND_FLOOR));//12.34  
  79.         System.out.println(round(-12.3401,2,BigDecimal.ROUND_FLOOR));//-12.35  
  80.         //ROUND_HALF_UP [這種方法最常用]  
  81.         //如果第3位數字>=5,則第2位數字+1  
  82.         //備註:只看第3位數字的值,不會考慮第3位之後的小數的  
  83.         System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_UP));//12.35  
  84.         System.out.println(round(12.3449,2,BigDecimal.ROUND_HALF_UP));//12.34  
  85.         System.out.println(round(-12.345,2,BigDecimal.ROUND_HALF_UP));//-12.35  
  86.         System.out.println(round(-12.3449,2,BigDecimal.ROUND_HALF_UP));//-12.34  
  87.         //ROUND_HALF_DOWN  
  88.         //如果第3位數字>=5,則做ROUND_UP  
  89.         //如果第3位數字<5,則做ROUND_DOWN  
  90.         System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_DOWN));//12.35  
  91.         System.out.println(round(12.3449,2,BigDecimal.ROUND_HALF_DOWN));//12.34  
  92.         System.out.println(round(-12.345,2,BigDecimal.ROUND_HALF_DOWN));//-12.35  
  93.         System.out.println(round(-12.3449,2,BigDecimal.ROUND_HALF_DOWN));//-12.34  
  94.         //ROUND_HALF_EVEN  
  95.         //如果第3位是偶數,則做ROUND_HALF_DOWN  
  96.         //如果第3位是奇數,則做ROUND_HALF_UP  
  97.         System.out.println(round(12.346,2,BigDecimal.ROUND_HALF_EVEN));//12.35  
  98.         System.out.println(round(12.345,2,BigDecimal.ROUND_HALF_EVEN));//12.35  
  99.     }  
  100. }  


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章