精确计算工具类,提供加减乘除的计算

package com.ljq.util;

import java.math.BigDecimal;

/**
 * 精确计算工具类,提供加减乘除的计算
 *
 * @author jqlin
 */
public class CompuUtils {
    /**小数点后保留的位数*/
    public final static int SCALE = 5;
    /** 0 */
    public final static int ZERO = 0;

    /**
     * BigDecimal大小比较
     *
     * @param a
     * @param b
     * @return 返回1, 表示a大于b <br/>
     *                  返回0 ,表示a等于b <br/>
     *         返回-1,表示a小于b
     * @author jqlin
     */
    public static int compareTo(BigDecimal a, BigDecimal b){
        return a.compareTo(b);
    }

    /**
     * 加法运算
     *
     * @param a 被加数
     * @param b 加数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal add(BigDecimal a, BigDecimal b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }
        return a.add(b).setScale(scale, BigDecimal.ROUND_HALF_UP);
    }

    /**
     * 加法运算
     *
     * @param a 被加数
     * @param b 加数
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal add(BigDecimal a, BigDecimal b) {
        return  add(a, b, SCALE);
    }

    /**
     * 加法运算
     *
     * @param a 被加数
     * @param b 加数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double add(double a, double b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }

        return add(new BigDecimal(a), new BigDecimal(b), scale).doubleValue();
    }

    /**
     * 加法运算
     *
     * @param a 被加数
     * @param b 加数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double add(double a, double b) {
        return add(new BigDecimal(a), new BigDecimal(b), SCALE).doubleValue();
    }

    /**
     * 减法运算
     *
     * @param a 被减数
     * @param b 减数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal subtract(BigDecimal a, BigDecimal b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }
        return a.subtract(b).setScale(scale, BigDecimal.ROUND_HALF_UP);
    }

    /**
     * 减法运算
     *
     * @param a 被减数
     * @param b 减数
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal subtract(BigDecimal a, BigDecimal b) {
        return subtract(a, b, SCALE);
    }

    /**
     * 减法运算
     *
     * @param a 被减数
     * @param b 减数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double subtract(double a, double b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }

        return subtract(new BigDecimal(a), new BigDecimal(b), scale).doubleValue();
    }

    /**
     * 减法运算
     *
     * @param a 被减数
     * @param b 减数
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double subtract(double a, double b) {
        return subtract(new BigDecimal(a), new BigDecimal(b), SCALE).doubleValue();
    }

    /**
     * 乘法运算
     *
     * @param a 被乘数
     * @param b 乘数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal multiply(BigDecimal a, BigDecimal b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }
        return a.multiply(b).setScale(scale, BigDecimal.ROUND_HALF_UP);
    }

    /**
     * 乘法运算
     *
     * @param a 被乘数
     * @param b 乘数
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal multiply(BigDecimal a, BigDecimal b) {
        return multiply(a, b, SCALE);
    }

    /**
     * 乘法运算
     *
     * @param a 被乘数
     * @param b 乘数
     * @param scale 小数点后保留几位, 默认保留5位小数点
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double multiply(double a, double b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }

        return multiply(new BigDecimal(a), new BigDecimal(b), scale).doubleValue();
    }

    /**
     * 乘法运算
     *
     * @param a 被乘数
     * @param b 乘数
     * @return 四舍五入后的结果
     * @author jqlin
     */
    public static double multiply(double a, double b) {
        return multiply(a, b, SCALE);
    }

    /**
     * 除法运算
     *
     * @param a 被除数
     * @param b 除数
     * @param scale 保留小数点后多少位, 默认保留5位小数点
     * @return  四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal divide(BigDecimal a, BigDecimal b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }

        return a.divide(b, scale, BigDecimal.ROUND_HALF_UP);
    }

    /**
     * 除法运算,默认保留5位小数点
     *
     * @param a 被除数
     * @param b 除数
     * @return    四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal divide(BigDecimal a, BigDecimal b) {
        return divide(a, b, SCALE);
    }

    /**
     * 除法运算
     *
     * @param a 被除数
     * @param b 除数
     * @param scale 保留小数点后多少位, 默认保留5位小数点
     * @return  四舍五入后的结果
     * @author jqlin
     */
    public static BigDecimal divide(double a, double b, int scale) {
        if(scale < 0){
            scale = SCALE;
        }

        return divide(new BigDecimal(a), new BigDecimal(b), scale);
    }

    /**
     * 除法运算,默认保留5位小数点
     *
     * @param a 被除数
     * @param b 除数
     * @return    四舍五入后的结果
     * @author jqlin
     */
    public static double divide(double a, double b) {
        return divide(a, b, SCALE).doubleValue();
    }

}
时间: 2024-12-18 23:29:04

精确计算工具类,提供加减乘除的计算的相关文章

由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精 确的浮点数运算,包括加减乘除和四舍五入

public class Arith { /** * 由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精 确的浮点数运算,包括加减乘除和四舍五入. */ // 默认除法运算精度 private static final int DEF_DIV_SCALE = 10; // 这个类不能实例化 private Arith() { } /** * 提供精确的加法运算. * * @param v1 * 被加数 * @param v2 * 加数 * @return 两个参数的和 */ p

工具类---提供精确的浮点数运算

import java.math.BigDecimal; /** * 由于Java的简单类型不能够精确的对浮点数进行运算, 这个工具类提供精 确的浮点数运算,包括加减乘除和四舍五入. */ public class Arith { // 默认除法运算精度.除法的时候,默认的精确到小数点后10位 private static final int DEF_DIV_SCALE = 10; // 这个类不能实例化 private Arith() { } /** * 提供精确的加法运算. * * @par

java精确计算工具类

import java.math.BigDecimal; import java.math.RoundingMode; import java.math.BigDecimal; import java.text.DecimalFormat; import org.springframework.stereotype.Component; /** * 工具类 - 运算 */ @Component public class ArithUtils { // 默认除法运算精度 private stati

java工具类 六 根据经纬度计算距离

Java实现根据经纬度计算距离 在项目开发过程中,需要根据两地经纬度坐标计算两地间距离,所用的工具类如下: Demo1: public static double getDistatce(double lat1, double lat2, double lon1, double lon2) { double R = 6371; double distance = 0.0; double dLat = (lat2 - lat1) * Math.PI / 180; double dLon = (lo

JAVA简单精确计算工具类

1 public class ArithUtil { 2 3 // 默认除法运算精度 4 private static final int DEF_DIV_SCALE = 10; 5 6 private ArithUtil() { 7 8 } 9 10 /** 11 * 提供精确的加法运算. 12 * 13 * @param v1 14 * 被加数 15 * @param v2 16 * 加数 17 * @return 两个参数的和 18 */ 19 public static double a

黑马程序员---工具类---OC自定义函数---计算当前路径下所有文件的总行数

------iOS培训.Java培训.Android培训, iOS学习型技术博客,期待与您交流------ 计算当前路径下所有文件的总行数 /* 计算当前路径下所有文件的总行数 涉及到NSArray.NSString.NSFileManager */ // 计算当前全路径(文件\文件夹)下所有文件的行数 // 接收参数path:文件的全路径(文件.文件夹) NSUInteger codeLinesCount(NSString *path) { // 1.获得文件管理者    单例模式:整个程序的

精度更高的double类型计算工具类(借助BigDecimal类型)

/** * 提供精確的加法運算 * @param args */ 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

BigDecimal工具类处理精度计算

1 /** 2 * Created by My_coder on 2017-07-27. 3 * 加减乘除计算工具类 4 */ 5 public class BigDecimalUtil { 6 private BigDecimalUtil() { 7 } 8 9 /** 10 * 加 11 */ 12 public static BigDecimal add(Double v1, Double v2){ 13 BigDecimal b1 = new BigDecimal(v1.toString

java工具类-BigDecimal

1 package hello; 2 3 import java.math.BigDecimal; 4 5 /** 6 * 由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精 确的浮点数运算,包括加减乘除和四舍五入. 7 */ 8 public class BigDecimalUtil { 9 10 // 默认除法运算精度 11 private static final int DEF_DIV_SCALE = 10; 12 13 // 这个类不能实例化 14 private B