BigDecimal的使用

简介: BigDecimal的使用

BigDecimal类型(+ - * /)所用的属性

11.10 BigDecimal类


对于不需要任何准确计算精度的数字可以直接使用float或double,但是如果需要精确计算的结果,则必须使用BigDecimal类,而且使用BigDecimal类也可以进行大数的操作。BigDecimal类的常用方法如表11-15所示。


表11-15 BigDecimal类的常用方法

序号

方    法 类型     述

1

public BigDecimal(double val)

构造

将double表示形式转换

为BigDecimal

2

public BigDecimal(int val)

构造

将int表示形式转换为

BigDecimal

3

public BigDecimal(String val)

构造

将字符串表示

形式转换为BigDecimal

4

public BigDecimal add(BigDecimal augend)

普通

加法

5

public BigDecimal subtract(BigDecimal
subtrahend)

普通

减法

6

public BigDecimal multiply(BigDecimal
multiplicand)

普通

乘法

7

public BigDecimal divide(BigDecimal
divisor)

普通

除法

范例:进行四舍五入的四则运算
package org.lxh.demo11.numberdemo;
import java.math.BigDecimal;
class MyMath {
    public static double add(double d1, double d2)
{        // 进行加法运算
         BigDecimal b1 = new BigDecimal(d1);
         BigDecimal b2 = new BigDecimal(d2);
        return b1.add(b2).doubleValue();
     }
    public static double sub(double d1, double d2)
{        // 进行减法运算
         BigDecimal b1 = new BigDecimal(d1);
         BigDecimal b2 = new BigDecimal(d2);
        return b1.subtract(b2).doubleValue();
     }
    public static double mul(double d1, double d2)
{        // 进行乘法运算
         BigDecimal b1 = new BigDecimal(d1);
         BigDecimal b2 = new BigDecimal(d2);
        return b1.multiply(b2).doubleValue();
     }
    public static double div(double d1,
double d2,int len) {// 进行除法运算
         BigDecimal b1 = new BigDecimal(d1);
         BigDecimal b2 = new BigDecimal(d2);
        return b1.divide(b2,len,BigDecimal.
ROUND_HALF_UP).doubleValue();
     }
    public static double round(double d,
int len) {     // 进行四舍五入
操作
         BigDecimal b1 = new BigDecimal(d);
         BigDecimal b2 = new BigDecimal(1);
        // 任何一个数字除以1都是原数字
        // ROUND_HALF_UP是BigDecimal的一个常量,
表示进行四舍五入的操作
        return b1.divide(b2, len,BigDecimal.
ROUND_HALF_UP).doubleValue();
     }
}
public class BigDecimalDemo01 {
    public static void main(String[] args) {
         System.out.println("加法运算:" +
MyMath.round(MyMath.add(10.345,
3.333), 1));
         System.out.println("乘法运算:" +
MyMath.round(MyMath.mul(10.345,
3.333), 3));
         System.out.println("除法运算:" +
MyMath.div(10.345, 3.333, 3));
         System.out.println("减法运算:" +
MyMath.round(MyMath.sub(10.345,
3.333), 3));
     }
}

BigDecimal比较


BigDecimal是通过使用compareTo(BigDecimal)来比较的,具体比较情况如下:

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。

相关文章
|
5天前
如何对BigDecimal进行非0判断
如何对BigDecimal进行非0判断
23 3
|
5天前
|
Java
BigDecimal的相关使用
BigDecimal的相关使用
29 1
|
9月前
|
Java API
BigDecimal类型讲解
如何在Java中使用BigDecimal数字类型,你真的掌握了嘛??
72 0
|
5天前
|
存储 Java
BigDecimal 详解
BigDecimal 详解
40 8
|
9月前
|
Java API
关于BigDecimal你不知道的那些事儿
在我们平时开发中,涉及到精度计算的逻辑肯定会用到BigDecimal,Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以开发中,如果我们需要精确计算的结果,则必须使用BigDecimal类来操作。 ————————————————
43 0
关于BigDecimal你不知道的那些事儿
|
5天前
|
Java API
使用 BigDecimal 的正确方式
使用 BigDecimal 的正确方式
33 1
|
8月前
|
存储 Java
BigInteger与BigDecimal类
BigInteger与BigDecimal类
47 0
|
8月前
|
Java
BigDecimal详解和精度问题
BigDecimal详解和精度问题
53 0
|
9月前
|
Java
BigInteger
BigInteger
48 0
|
11月前
|
缓存 安全 Java
BigDecimal
BigDecimal
3097 3