学习目标:
目标:熟练运用Java所学知识
学习内容:
本文内容:
最近在刷题的时候,经常涉及到对数字的加减乘除的操作,而且有的题目数字的长度会超出整数的范围,所以必须对字符串进行加减乘除,感觉非常的麻烦而且效率不高,所以在这篇文章中,我介绍了一种类,可以完美的解决这种问题:Java中的BigDecimal类
1.BigDecimal类的介绍
Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。
双精度浮点型变量double可以处理16位有效数。
在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。
BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象
2.BigDecimal类的构造方法
BigDecimal一共有4个构造方法:
- BigDecimal(int) 创建一个具有参数所指定整数值的对象。
- BigDecimal(double) 创建一个具有参数所指定双精度值的对象。(不建议采用)
- BigDecimal(long) 创建一个具有参数所指定长整数值的对象。
- BigDecimal(String) 创建一个具有参数所指定以字符串表示的数值的对象
对于这个类我们一般不采用第二种构造方法,因为第二种构造方法的double参数具有一定的不可预知性,如下代码:
BigDecimal bigDecimal=new BigDecimal(0.1);
System.out.println(bigDecimal);
//运行结果
0.1000000000000000055511151231257827021181583404541015625
所以一般可以使用第四种构造方法,如下代码
BigDecimal bigDecimal1=new BigDecimal(0.1+"");
BigDecimal bigDecimal2=new BigDecimal(Double.toString(0.1));
System.out.println("bigDecimal1="+bigDecimal1);
System.out.println("bigDecimal2="+bigDecimal2);
//运行结果
bigDecimal1=0.1
bigDecimal2=0.1
3.BigDecimal类中方法的使用
BigDecimal中最常用的就是加减乘除
对于常用的加,减,乘,除,BigDecimal类提供了相应的成员方法 。
public BigDecimal add(BigDecimal value); //加法
public BigDecimal subtract(BigDecimal value); //减法
public BigDecimal multiply(BigDecimal value); //乘法
public BigDecimal divide(BigDecimal value); //除法
方法使用的演示
BigDecimal b1=new BigDecimal("111111111111111111");
BigDecimal b2=new BigDecimal("222222222222222222");
System.out.println("b1 + b2 = "+b2.add(b1));//加法
System.out.println("b1 - b2 = "+b1.subtract(b2));//减法
System.out.println("b2 - b1 = "+b2.subtract(b1));//减法
BigDecimal b3=new BigDecimal(6);
BigDecimal b4=new BigDecimal(3);
System.out.println("b3 / b4 = "+b3.divide(b4));//除法
System.out.println("b4 / b3 = "+b4.divide(b3));//除法
System.out.println("b3 * b4 = "+b3.multiply(b4));//乘法
//运行结果
b1 + b2 = 333333333333333333
b1 - b2 = -111111111111111111
b2 - b1 = 111111111111111111
b3 / b4 = 2
b4 / b3 = 0.5
b3 * b4 = 18
还有一些其他可能会用到的方法
//返回调用该方法的BigDecimal对象和参数value中较小的一个
public BigDecimal min(BigDecimal value);//返回调用该方法的BigDecimal对象和参数value中较大的一个
public BigDecimal max(BigDecimal value);//比较大小,调用该方法的BigDecimal对象小于参数返回小于0的数,等于参数返回0,大于参数返回大于0的数
public int compareTo(BigDecimal val)
方法演示:
BigDecimal b5=new BigDecimal(6);
BigDecimal b6=new BigDecimal(3);
System.out.println("b5,b6中较大的:"+b5.max(b6));
System.out.println("b5,b6中较小的:"+b5.min(b6));
System.out.println(b5.compareTo(b6));
System.out.println(b6.compareTo(b5));
//运行结果
b5,b6中较大的:6
b5,b6中较小的:3
1
-1