Java——BigInteger类和BigDecimal类
Java——BigInteger类和BigDecimal类
摘要:本文主要学习了用于大数字运算的BigInteger类和BigDecimal类。
部分内容来自以下博客:
https://www.cnblogs.com/LeoBoy/p/6056394.html
https://www.cnblogs.com/linjiqin/p/3413894.html
使用BigInteger类
为什么要使用BigInteger类
在Java的整数类型里面,byte为8位,short为16位,int为32位,long为64位。正因为这些数值的二进制位数已经固定,所以它们能表示的数值大小就有一定的范围限制。因此,Java中提供BigInteger类来处理更大的数字。
构造方法
BigInteger(String val):创建一个具有参数所指定以字符串表示的数值的对象。
常用方法
BigInteger add(BigInteger val):加法运算。
BigInteger subtract(BigInteger val):减法运算。
BigInteger multiply(BigInteger val) :乘法运算。
BigInteger divide(BigInteger val) :除法运算,可能会产生除零异常。
public BigInteger[] divideAndRemainder(BigInteger val):获取商值和余数组成的数组,初始元素是商值,最终元素是余数。
String toString():将BigInteger对象的数值转换成字符串。
double doubleValue():将BigInteger对象中的值以双精度数返回。
float floatValue():将BigInteger对象中的值以单精度数返回。
long longValue():将BigInteger对象中的值以长整数返回。
int intValue():将BigInteger对象中的值以整数返回。
使用代码
代码如下:
1 public void test() { 2 BigInteger a = new BigInteger("10"); 3 BigInteger b = new BigInteger("3"); 4 System.out.println("add >>> " + a.add(b)); 5 System.out.println("subtract >>> " + a.subtract(b)); 6 System.out.println("multiply >>> " + a.multiply(b)); 7 System.out.println("divide >>> " + a.divide(b)); 8 System.out.println("divideAndRemainder[0] >>> " + a.divideAndRemainder(b)[0]); 9 System.out.println("divideAndRemainder[1] >>> " + a.divideAndRemainder(b)[1]); 10 }
运行结果如下:
1 add >>> 13 2 subtract >>> 7 3 multiply >>> 30 4 divide >>> 3 5 divideAndRemainder[0] >>> 3 6 divideAndRemainder[1] >>> 1
使用BigDecimal类
为什么要使用BigDecimal类
虽然Java的基本类型提供了float和double类型,但他们在执行浮点运算的时候,只是提供了一个较为精确的结果,不能用于要求精确度很高的环境中。
因此,Java提供了BigDecimal类来保证结果的精确度。
BigDecimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象,所以在做运算时千万要保存操作后的值。
使用BigDecimal的坏处是性能比double和float差,在处理庞大,复杂的运算时尤为明显,因根据实际需求决定使用哪种类型。
使用float和double导致精度缺失
在使用基本类型的float和double的时候,可能会出现精度缺失的问题,代码如下:
1 public void test() { 2 System.out.println(0.2 + 0.1); 3 System.out.println(0.3 - 0.1); 4 System.out.println(0.2 * 0.1); 5 System.out.println(0.3 / 0.1); 6 }
运行结果如下:
1 0.30000000000000004 2 0.19999999999999998 3 0.020000000000000004 4 2.9999999999999996
我们使用BigDecimal类来解决使用浮点类型导致精度缺失的问题。
构造方法
BigDecimal(int):创建一个具有参数所指定整数值的对象。
BigDecimal(double):创建一个具有参数所指定双精度值的对象(不建议使用)。
BigDecimal(String):创建一个具有参数所指定以字符串表示的数值的对象。
不使用传入double的构造方法
因为float和double会导致精度缺失的问题,所以不建议使用将double作为参数的构造方法,代码如下:
1 public void test() { 2 BigDecimal a = new BigDecimal(2); 3 BigDecimal b = new BigDecimal(2.3); 4 BigDecimal c = new BigDecimal("2.3"); 5 System.out.println(a); 6 System.out.println(b); 7 System.out.println(c); 8 }
运行结果如下:
1 2 2 2.29999999999999982236431605997495353221893310546875 3 2.3
常用方法
BigDecimal add(BigDecimal augend):加法运算。
BigDecimal subtract(BigDecimal subtrahend):减法运算。
BigDecimal multiply(BigDecimal multiplicand):乘法运算。
BigDecimal divide(BigDecimal divisor):除法运算,可能会产生除零异常和不能整除异常。
BigDecimal divide(BigDecimal divisor, int scale, int roundingMode):除法运算,可传入精确小数位数scale,和舍入模式roundingMode。
BigDecimal[] divideAndRemainder(BigDecimal divisor):获取商值和余数组成的数组,初始元素是商值,最终元素是余数。
BigDecimal setScale(int newScale, int roundingMode):进行舍入操作。
String toString():将BigDecimal对象的数值转换成字符串。
double doubleValue():将BigDecimal对象中的值以双精度数返回。
float floatValue():将BigDecimal对象中的值以单精度数返回。
int intValue():将BigDecimal对象中的值以整数返回。
舍入模式
ROUND_UP:向远离零的方向舍入。舍弃非零部分,并将非零舍弃部分相邻的一位数字加一。
ROUND_DOWN:向接近零的方向舍入。舍弃非零部分,同时不会非零舍弃部分相邻的一位数字加一,采取截取行为。
ROUND_CEILING:向正无穷的方向舍入。如果为正数,舍入结果同ROUND_UP一致;如果为负数,舍入结果同ROUND_DOWN一致。
ROUND_FLOOR:向负无穷的方向舍入。如果为正数,舍入结果同ROUND_DOWN一致;如果为负数,舍入结果同ROUND_UP一致。
ROUND_HALF_UP:向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。这种模式也就是我们常说的我们的“四舍五入”。
ROUND_HALF_DOWN:向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则为向下舍入的舍入模式。这种模式也就是我们常说的我们的“五舍六入”。
ROUND_HALF_EVEN:向“最接近”的数字舍入,如果与两个相邻数字的距离相等,则相邻的偶数舍入。如果舍弃部分左边的数字奇数,则舍入行为与ROUND_HALF_UP相同;如果为偶数,则舍入行为与ROUND_HALF_DOWN相同。四舍六入,五分两种情况,如果前一位为奇数,则入位,否则舍去。
ROUND_UNNECESSARY:断言请求的操作具有精确的结果,因此不需要舍入。如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。
使用代码
代码如下:
1 public void test() { 2 BigDecimal a = new BigDecimal(10); 3 BigDecimal b = new BigDecimal(3); 4 System.out.println("add >>> " + a.add(b)); 5 System.out.println("subtract >>> " + a.subtract(b)); 6 System.out.println("multiply >>> " + a.multiply(b)); 7 // System.out.println("divide >>> " + a.divide(b));// Non-terminating decimal expansion; no exact representable decimal result. 8 System.out.println("divide >>> " + a.divide(b, 2, BigDecimal.ROUND_HALF_UP)); 9 System.out.println("divideAndRemainder[0] >>> " + a.divideAndRemainder(b)[0]); 10 System.out.println("divideAndRemainder[1] >>> " + a.divideAndRemainder(b)[1]); 11 }
运行结果如下:
1 add >>> 13 2 subtract >>> 7 3 multiply >>> 30 4 divide >>> 3.33 5 divideAndRemainder[0] >>> 3 6 divideAndRemainder[1] >>> 1
转载于:https://www.cnblogs.com/shamao/p/10943539.html
Java——BigInteger类和BigDecimal类相关推荐
- JAVA基础再回首(十三)——BigInteger类、BigDecimal类、Date类、DateFormat类、Calendar类
JAVA基础再回首(十三)--BigInteger类.BigDecimal类.Date类.DateFormat类.Calendar类 版权声明:转载必须注明本文转自程序员杜鹏程的博客:http://b ...
- NumberFormat类、BigInteger类和BigDecimal类-JAVA
JAVA数学计算函数的总结 提示:以下是本篇文章正文内容,下面案例可供参考 1.NumberFormat类: (public abstract class NumberFormat extends F ...
- 4、大数字运算(BigInteger类和BigDecimal类)
在 Java 中提供了用于大数字运算的类,即 java.math.BigInteger 类和 java.math.BigDecimal 类.这两个类用于高精度计算,其中 BigInteger 类是针对 ...
- 15.Java-正则表达式、Pattern和Matcher类、Math类、Random类、System类、BigDecimal类、BigInteger类
15.Java-正则表达式.Pattern和Matcher类.Math类.Random类.System类.BigDecimal类.BigInteger类 一.正则表达式的概述和简单使用 A:正则表达式 ...
- Java面试知识点:Object类、Math类、BigDecimal类、自动装箱、拆箱
问题:Java面试知识点:Object类.BigDecimal类.自动装箱.拆箱 答案: 1.Object类: 代码如下: package com.xy;/*** @ProjectName: day0 ...
- 正则表达式、常用类(Pattern类、Matcher类、Math类、System类、Random类、BigDecimal类、Date类、SimpleDateFormat类、Calendar类)
JAVA学习第十六天-正则表达式.常用类(Pattern类.Matcher类.Math类.System类.Random类.BigDecimal类.Date类.SimpleDateFormat类.Cal ...
- java final bigd_java中的BigInteger类和BigDecimal类的应用
JAVA的两个类BigInteger和BigDecimal分别表示大整数类和大浮点数类,理论上能够表示无限大的数. BigInteger表示: package com.xujin; import ja ...
- Java大数字运算(BigInteger类和BigDecimal类)
Java中的超大数BIgInteger和BigDecimal 在我们处理大位数运算的时候,我们经常用的int和long类型的数已经不能够满足我们的运算了,那么这个时候就需要用到一个超大数来运算,这个时 ...
- Math类,随机数Random类,System类,BigInteger类,BigDecimal类,Date类,Calendar类
Math类概述:Math 类涵盖了很多执行基本数学运算的方法, 是一个工具类. package com.sxt.mathdemo;/** Math类概述:Math 类涵盖了很多执行基本数学运算的方法, ...
最新文章
- 一次失败的Pytorch模型量化尝试
- C# in depth 阅读笔记-- 委托
- arcgis下的python编程-面向ArcGIS的Python脚本编程
- 【控制】《复杂运动体系统的分布式协同控制与优化》-方浩老师-第11章-意图场模型干预下的人机共享控制
- python-3.x-基本数据类型
- 从重采样到数据合成:如何处理机器学习中的不平衡分类问题? 转载 2017年08月01日 17:09:03 标签: 机器学习 / 数据 719 转自:http://www.sohu.com/a/12
- Java与汽车_Java NIO:IO与NIO的区别
- spring的annotation-driven配置事务管理器详解
- [xsd学习]xsd介绍
- 间歇性掉帧卡顿_电脑卡顿问题靠它解决,我只能帮你到这儿了
- ride上点击用例不能显示edit信息_接口测试平台代码实现61: 多接口用例1
- 智能投影:下一个传统投影的颠覆者
- SEO中HTML标签权重列表
- 算法21----重塑矩阵 LeetCode566
- 表单从gb2312的页面提交到utf-8页面,或者表单从utf-8的页面提交到gb2312页面的解决办法...
- 工程力学考研 可以转计算机专业吗,跨专业考研我是工程力学的本科生,想要考飞行 – 手机爱问...
- 使用TortoiseSVN下载source force的源代码
- EasyX实现按钮效果
- 为啥俺要写博客--凭什么?
- 【React】377- 实现 React 中的状态自动保存