菲诗小铺洗发水多少钱:java中BigDecimal与double的精度控制

来源:百度文库 编辑:九乡新闻网 时间:2024/07/07 10:01:54
本篇介绍了在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的精度取值方式分为以下几种: 
     
  15.  * java.math.BigDecimal.ROUND_UP 
     
  16.  * java.math.BigDecimal.ROUND_DOWN 
     
  17.  * java.math.BigDecimal.ROUND_CEILING 
     
  18.  * java.math.BigDecimal.ROUND_FLOOR 
     
  19.  * java.math.BigDecimal.ROUND_HALF_UP
     
  20.  * java.math.BigDecimal.ROUND_HALF_DOWN 
     
  21.  * java.math.BigDecimal.ROUND_HALF_EVEN 
     
  22.  *   
  23.  * @author stephen  
  24.  * @version 1.0.0  
  25.  */  
  26. public final class RoundTool {   
  27.   
  28.     /**  
  29.      * 对double数据进行取精度.  
  30.      * 

     

  31.      * For example: 
     
  32.      * double value = 100.345678; 
     
  33.      * double ret = round(value,4,BigDecimal.ROUND_HALF_UP); 
     
  34.      * ret为100.3457 
     
  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. }