我是靠谱客的博主 清新老鼠,最近开发中收集的这篇文章主要介绍BigDecimal基础用法BigDecimal基础用法(加减乘除与比较大小),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

BigDecimal基础用法(加减乘除与比较大小)

一:构造方法详解

  1. BigDecimal(int)       创建一个具有参数所指定整数值的对象
  2. BigDecimal(double) 创建一个具有参数所指定双精度的对象
  3. BigDecimal(long)     创建一个具有参数所指定长整数值的对象
  4. BigDecimal(String)   创建一个具有参数所指定已字符串表示的对象

二:方法描述

  1. add(BigDecimal)           BigDecimal对象中的值相加,然后返回这个对象。
  2. subtract(BigDecimal)    BigDecimal对象中的值相减,然后返回这个对象。
  3. mulitply(BigDecimal)    BigDecimal对象中的值相乘,然后返回这个对象。
  4. divdie(BigDecimal)       BigDecimal对象中的值相除,然后返回这个对象。
  5. toString()        将BigDecimal对象的数值转换成字符串。
  6. doubleValue() 将BigDecimal对象中的值以双精度数返回。
  7. floatValue()     将BigDecimal对象中的值以单精度数返回。
  8. longValue()     将BigDecimal对象中的值以长整数返回。
  9. intValue()        将BigDecimal对象中的值以整数返回。

三:加减乘除

import java.math.BigDecimal;

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

    private Arith() {
    }

    /**
     * 提供精确的加法运算。
     *
     * @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();
    }
} 

四:比较大小

import java.math.BigDecimal;

/**
 * BigDecimal比较大小
 */
public class Arith { //默认除法运算精度

    public static void main(String[] args) {
        BigDecimal a = new BigDecimal("1");
        BigDecimal b = new BigDecimal("2");
        BigDecimal c = new BigDecimal("1");
        int result1 = a.compareTo(b);
        int result2 = a.compareTo(c);
        int result3 = b.compareTo(a);
        System.out.println(result1);
        System.out.println(result2);
        System.out.println(result3);
    }
}

打印结果:

-1 0 1 ,即左边比右边数大,返回1,相等返回0,比右边小返回-1。
注意:

不可用equals()方法拉比较大小, 使用BigDecimal的坏处是性能比double和float差,在处理庞大,复杂的运算时尤为明显,因根据实际需求决定使用哪种类型。

最后

以上就是清新老鼠为你收集整理的BigDecimal基础用法BigDecimal基础用法(加减乘除与比较大小)的全部内容,希望文章能够帮你解决BigDecimal基础用法BigDecimal基础用法(加减乘除与比较大小)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部