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

技术
今日推荐
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信