【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[]




目录
相关文章
|
8月前
|
存储 C语言 C++
截断&&整型提升&&算数转换
截断&&整型提升&&算数转换
|
5月前
|
C语言
用栈实现将一个十进制数值转换成八进制数值。即用该十进制数值除以8,并保留其余数;重复此操作,直到该十进制数值为0为止。最后将所有的余数反向输出就是所对应的八进制数值
这篇文章展示了如何使用栈(包括顺序栈和链栈)实现将十进制数值转换成八进制数值的方法,通过C语言编程演示了两种栈的实现方式和使用场景。
用栈实现将一个十进制数值转换成八进制数值。即用该十进制数值除以8,并保留其余数;重复此操作,直到该十进制数值为0为止。最后将所有的余数反向输出就是所对应的八进制数值
|
8月前
|
算法
实现一个标准数字字符串四舍五入截取不指定位数的小数
实现一个标准数字字符串四舍五入截取不指定位数的小数
50 0
|
8月前
|
编译器 C语言 C++
整形提升和算数转换
整形提升和算数转换
47 0
|
8月前
|
算法 Python
计算32位二进制整数中1的个数(包括负数补码)
计算32位二进制整数中1的个数(包括负数补码)
136 0
|
C语言
整数和浮点数的任意进制转!!(包括16进制)确定不进来看看?!
整数和浮点数的任意进制转!!(包括16进制)确定不进来看看?!
160 0
|
C语言
已知一个整数,如何判断这个整数是无符号的?
已知一个整数,如何判断这个整数是无符号的?
101 0
【C语言】输入一个整数,输出该数二进制表示中1的个数,其中负数用补码表示
输入一个整数,输出该数二进制表示中1的个数,其中负数用补码表示
【c++】关于数值进制以及进制之间转化
【c++】关于数值进制以及进制之间转化
207 0
【c++】关于数值进制以及进制之间转化