BigDecimal 상용 방법 도구 류

4318 단어 JAVA
BigDecimal.java 확장 클래스:
import java.math.BigDecimal; 
public class DecimalCalculate
{ 
/** 
*   Java                   ,         
*        ,           。 
*/ 
//         
private static final int DEF_DIV_SCALE = 10; 
    
//         
private DecimalCalculate(){ 
} 
    /** 
     *          。 
     * @param v1     
     * @param v2    
     * @return        
     */ 
    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(); 
    } 
    /** 
     *          。 
     * @param v1     
     * @param v2    
     * @return        
     */ 
    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(); 
    } 
    /** 
     *          。 
     * @param v1     
     * @param v2    
     * @return        
     */ 
    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(); 
    } 
    /** 
     *   (  )       ,          ,    
     *      10 ,         。 
     * @param v1     
     * @param v2    
     * @return        
     */ 
    public static double div(double v1,double v2){ 
        return div(v1,v2,DEF_DIV_SCALE); 
    } 
    /** 
     *   (  )       。          , scale    
     *    ,         。 
     * @param v1     
     * @param v2    
     * @param scale                 。 
     * @return        
     */ 
    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(); 
    } 
    /** 
     *               。 
     * @param v           
     * @param scale          
     * @return          
     */ 
    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(); 
    } 
    
   /** 
    *          (Float) 
    * @param v          
    * @return        
    */ 
    public static float convertsToFloat(double v){ 
    BigDecimal b = new BigDecimal(v); 
    return b.floatValue(); 
    } 
    
    /** 
*          (Int)        
* @param v          
* @return        
*/ 
public static int convertsToInt(double v){ 
BigDecimal b = new BigDecimal(v); 
    return b.intValue(); 
} 
/** 
*          (Long) 
* @param v          
* @return        
*/ 
public static long convertsToLong(double v){ 
BigDecimal b = new BigDecimal(v); 
    return b.longValue(); 
} 
/** 
*             
* @param v1            
* @param v2            
* @return             
*/ 
public static double returnMax(double v1,double v2){ 
BigDecimal b1 = new BigDecimal(v1); 
BigDecimal b2 = new BigDecimal(v2); 
    return b1.max(b2).doubleValue(); 
} 
/** 
*             
* @param v1            
* @param v2            
* @return             
*/ 
public static double returnMin(double v1,double v2){ 
BigDecimal b1 = new BigDecimal(v1); 
BigDecimal b2 = new BigDecimal(v2); 
    return b1.min(b2).doubleValue(); 
} 
/** 
*          
* @param v1            
* @param v2            
* @return           0,               1,    -1 
*/ 
public static int compareTo(double v1,double v2){ 
BigDecimal b1 = new BigDecimal(v1); 
BigDecimal b2 = new BigDecimal(v2); 
    return b1.compareTo(b2); 
} 

} 

테스트 예:
public class Test1 {
	public static void main(String[] args) {
		double info = 0.000;
		double base = DecimalCalculate.div(5, 14, 3);
		info += (-1) * base * Math.log(base);
		System.out.println(info);
	}
}

좋은 웹페이지 즐겨찾기