Doule运算工具类(BigDecimal)和工具方法

Double运算工具类

public class DecimalUtil {
    private static final int DEF_DIV_SCALE = 2; //这个类不能实例化   
    /**  
    * 提供精确的加法运算。  
    * @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();   
    }   
}

Hibernate或者sql时间查询中时间加一减一的格式方法

    /**
     * 获取当前时间当天0点0分,:2018-01-12 00:00:00
     * 
     * @param date
     * @return
     */
    public static Date getcurZero(Date date) {
        if (null == date) date = new Date();
        long time = date.getTime();
        long zero = time / (1000 * 3600 * 24) * (1000 * 3600 * 24) - TimeZone.getDefault().getRawOffset();// 今天零点零分零秒的毫秒数
        return new Timestamp(zero);
    }

    /**
     * 获取当前时间,第二天的零点:2018-01-12 00:00:00
     * 
     * @param date
     * @return
     */
    public static Date getNextZero(Date date) {
        if (null == date) date = new Date();
        long next = date.getTime() + 24 * 60 * 60 * 1000;// 明天的这一时间的毫秒数
        long zero = next / (1000 * 3600 * 24) * (1000 * 3600 * 24) - TimeZone.getDefault().getRawOffset();// 零点零分零秒的毫秒数
        return new Timestamp(zero);
    }

时间格式化的工具类


    private static SimpleDateFormat sdf = null;

    /**
     * 根据时间返回MM-dd(02-14)这样的值
     * 
     * @param date
     *            如果为null 默认当前时间
     * @return
     */
    public static String dateFormatMd(Date date) {
        if (null == date)
            date = new Date();
        sdf = new SimpleDateFormat(Constant.DATE_FORMAT_MD);
        return sdf.format(date);
    }

    public static String dateFormatMdhm(Date date) {
        if (null == date)
            date = new Date();
        sdf = new SimpleDateFormat(Constant.DATE_FORMAT_MDHM);
        return sdf.format(date);
    }

    /**
     * 根据时间返回yyyy-MM-dd(2017-02-14)这样的值
     * 
     * @param date
     *            如果为null 默认当前时间
     * @return
     */
    public static String dateFormaYmd(Date date) {
        if (null == date)
            date = new Date();
        sdf = new SimpleDateFormat(Constant.DATE_FORMAT_YMD);
        return sdf.format(date);
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值