BigDecimal大小判断

Posted Amy-Y

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BigDecimal大小判断相关的知识,希望对你有一定的参考价值。

BigDecimal详解:

  • Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。

equals方法会比较值和精确度,而compareTo则会忽略精度。

equals源码:
public boolean equals(Object anObject) //name2传入equals方法,anObject指向name2,name2是上转型对象

if (this == anObject) //this代指调用equals方法的name1,name1和name2地址不一样,继续向下运行
        return true;
    
    if (anObject instanceof String) //此处用于判断name2是否是String类或其子类,此处是,继续运行
        String anotherString = (String)anObject;//对象下转型
        int n = value.length;//在编译器中可看出value是全局变量,其前存在省略掉的this(即n = this.value),用于测量name1的长度
        if (n == anotherString.value.length) //判断name1和name2指向的字符串长度是否相等,此处相等,继续运行
            char v1[] = value;//将name1指向的字符串存入字符数组v1
            char v2[] = anotherString.value;//将name1指向的字符串存入字符数组v2
            int i = 0;
            while (n-- != 0) //利用循环,逐字符比对两字符串,若有任何不同,返回false,否则返回true
                if (v1[i] != v2[i])
                    return false;
                    i++;
            
            return true;
        
    
        return false;


以下是java.math.BigDecimal.compareTo()方法的声明

public int compareTo(BigDecimal val)

参数:

val-- 要与此BigDecimal比较的值。

返回值:

此方法,如果BigDecimal为小于val返回-1,如果BigDecimal为大于val返回1,如果BigDecimal为等于val返回0

下面的示例演示math.BigDecimal.compareTo()方法的用法。

public class BigdecimalTest

public static void main(String[] args)

   BigDecimal z1 = new BigDecimal("0"); 

   BigDecimal z2 = new BigDecimal("0.0"); 

   System.out.println(z1.equals(z2)); 

   System.out.println(z1.compareTo(z2));


输出结果:

1.false

2.0

开发者涨薪指南 48位大咖的思考法则、工作方式、逻辑体系

以上是关于BigDecimal大小判断的主要内容,如果未能解决你的问题,请参考以下文章

BigDecimal为啥可以精确计算

BigDecimal类型比较大小

BigDecimal数据的加 减 乘 除 N次幂运算 以及比较大小

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

使用BigDecimal进行精确的数值运算

BigDecimal 精度 和准确度问题