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

你可能感兴趣的:(java)