【BigDecima】不可变的,任意精度的有符号十进制数。

简介: 【BigDecima】不可变的,任意精度的有符号十进制数。


BigDecima作用及原理

  • BigDecimal:表示不可变的,任意精度的有符号十进制数
  • 作用
  • 用于小数的精确计算(解决小数运算精度失真问题)
  • 用于表示很大的小数
  • BigDecimal继承结构
  • java.lang.Object <=继承= java.lang.Number<=继承= java.math.BigDecimal
  • 创建实例对象
//通过传递长整型表示的小数来创建对象
//有一定不可预知性,得到的结果可能不精确,源码中直接将double类型转换为String类型,再调用传递String类型的构造方法。
BigDecimal bd1 = new BigDecimal(1.236); 
//通过传递字符串表示的小数来创建对象
BigDecimal bd2 = new BigDecimal("1.229");
//通过静态方法获取对象(不能超过double范围)
BigDecimal bd3 = BigDecimal.valueOf(10);
/*
1. 如果要表示的数字不大,没有超出double取值范围,建议使用静态方法。
2. 如果要表示的数字比较大,超出double取值范围,建议使用构造方法。
3.使用静态方法时,当我们传递的是0~10范围的整数,方法返回创建好的对象,不会重新new。
*/
  • 常用方法
  • public static BigDecimal valueOf(val):获取实例对象
  • public BigDecimal add(BigDecimal val):加法
  • public BigDecimal subtract(BigDecimal val):减
  • public BigDecimal multiply(BigDecimal val):乘
  • public BigDecimal divide(BigDecimal val):除
  • public BigDecimal divide(BigDecimal val,精准几位,舍入模式):除
  • 舍入模式,使用RoundingMode类中的枚举常量,常用RoundingMode.HALF_UP四舍五入。
  • 底层存储方式
  • 创建实例时构造方法或静态方法传入的数据会转换为字符串String
  • 扫描字符串每个字符,存储成字符数组char[]
  • 字符数组中的每一个元素都转换为对应的ASCII码存储进byte[]




目录
相关文章
|
7月前
|
C语言
C语言之将十进制整数转换为任意进制整数
C语言之将十进制整数转换为任意进制整数
157 0
|
7月前
对于十进制数 -1023,包含符号位在内,至少需要多少个二进制位表示该数
对于十进制数 -1023,包含符号位在内,至少需要多少个二进制位表示该数
52 0
|
11月前
|
C语言
整数和浮点数的任意进制转!!(包括16进制)确定不进来看看?!
整数和浮点数的任意进制转!!(包括16进制)确定不进来看看?!
103 0
|
11月前
|
C语言
已知一个整数,如何判断这个整数是无符号的?
已知一个整数,如何判断这个整数是无符号的?
63 0
【进制转换】— 包含整数和小数部分转换(二进制、八进制、十进制、十六进制)手写版,超详细
【进制转换】— 包含整数和小数部分转换(二进制、八进制、十进制、十六进制)手写版,超详细
10(可回看)【C语言 & 趣味算法】数制转换(常见,二进制、八进制、十进制、十六进制之间任意转换)
10(可回看)【C语言 & 趣味算法】数制转换(常见,二进制、八进制、十进制、十六进制之间任意转换)
10(可回看)【C语言 & 趣味算法】数制转换(常见,二进制、八进制、十进制、十六进制之间任意转换)
04:输出保留3位小数的浮点数
04:输出保留3位小数的浮点数
79 0
05:输出保留12位小数的浮点数
05:输出保留12位小数的浮点数
121 0
【c++】关于数值进制以及进制之间转化
【c++】关于数值进制以及进制之间转化
146 0
【c++】关于数值进制以及进制之间转化
定点数与浮点数简单解释
定点数 定点数:小数的位置是固定不变的。定点数又包括定点整数和定点小数。 定点小数:小数点隐含固定在最高数据位的左边,整数位则用于表示符号位,用于表示纯小数。
177 0
定点数与浮点数简单解释