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大小判断的主要内容,如果未能解决你的问题,请参考以下文章