JAVA对double或者float的浮点数精度计算控制方法

★★★ 本篇为原创,需要引用转载的朋友请注明:《 http://stephen830.iteye.com/blog/260776 》 谢谢支持!★★★ 

本篇介绍了在JAVA中如何对double或者float的浮点数进行精度计算,在JAVA中提供了多种参数来实现精度的不同控制方式。具体例子如下: 

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. }  

你可能感兴趣的:(double)