解决BigDecimal转long丢失精度的问题

作者:昊Zz 时间:2022-07-16 13:44:22 

我就废话不多说了,大家还是直接看代码吧~


 public static void main(String[] args) {
   BigDecimal asdBigDecimal = new BigDecimal(56.33347);
   long sad = asdBigDecimal.longValue();
   double asda = asdBigDecimal.doubleValue();
   System.out.println(sad);
   System.out.println(asda);
 }

运行结果:

56

56.33347

而且BigDecimal.longValue()还会自动四舍五入,不想舍去小数点的朋友要用doubleValue()

补充知识:BigDecimal与int、long之间的相互转换及基本数据类型知识掌握

(Java提供了两个用于高精度计算的类:BigInteger和BigDecimal。这两个类包含的方法、提供的操作与对基本类型所能执行的操作相似,只不过是以方法调用方式取代运算符方式来实现。等于是用速度换取了精度。 BigInteger支持任意精度的整数,在运算中可以准确地表示任何大小的整数值,而不会丢失任何信息。BigDecimal支持任何精度的定点数,可以用它进行精确的货币计算。

它们都扩展Number类且实现Comparable接口,可以使用new BigInteger(String)或new BigDecimal(String)来创建实例,使用add,substract,multiple,divide和remainder方法完成算数运算,使用compareTo方法比较两个大数字。

一般来说,BigInteger用的不是很多,BigDecimal用的稍微多一点,就比如说JDBC中,如果一个字段的数据库类型是Number, 那么getObject().getClass()的结果是java.math.BigDecimal。

BigInteger相比Integer的确可以用big来形容。它是用于科学计算,Integer只能容纳一个int, 所以最大值也就是2的31次访减去1,十进制为2147483647,如果需要计算更大的数,那么31位显然是不够用了,BigInteger能够容纳的位数那可就大了,我简单试了一下,上千位没有任何问题。除了容量大之外,BigInteger还封装了一些常见的操作,比如+-*/的基本操作,还有绝对值,相反数,最大公约数,是否是质数等等的运算。

BigDecimal的实现利用到了BigInteger, 所不同的是BigDecimal加入了小数位的概念,比如BigDecimal d = new BigDecimal(new BigInteger(ib),5);5表示的是5个小数位。BigDecimal可以用来做超大的浮点数的运算,比如+-*/的运算,其中除法运算是最复杂的,因为商的位数还有除不断的情况下末位小数点的处理都是需要考虑的。)

我们在实际开发过程中,BigDecimal是经常用到的一个数据类型,它和int、long之间可以项目转换。

int 转换成 BigDecimal 数据类型


//int 转换成 bigDecimal类型
 public static void intToBigDecimal(){
   int b = 5;
   BigDecimal a = new BigDecimal(b);
   System.out.println(a +"的数据类型是"+a.getClass().getName());
 }

Long转换成 BigDecimal 数据类型


//Long 类型转换成 bigDecimal
 public static void longToBigDecimal(){
   long b = 5;
   BigDecimal a = new BigDecimal(b);
   System.out.println(a +"的数据类型是"+a.getClass().getName());
 }

BigDecimal 转换成 Long数据类型


//bigDecimal 转换成 Long类型
 public static void bigDecimalToLong(){
   BigDecimal b = new BigDecimal(12);
   Long c = b.longValue();
   System.out.println(c+"的数据类型是"+c.getClass().getName());
 }

BigDecimal 转换成 int数据类型


//bigDecimal 转换成 int类型
   public static void bigDecimalToInt(){
     BigDecimal b = new BigDecimal(12);
     int c = b.intValue();
   }

附:基本数据类型及所占位数及初始值

基本数据类型所占位数初始值
byte字节型 1字节(8bit)0
short短整型 2字节(16bit)0
int整型 4字节(32bit)0
long长整型 8字节(64bit)0L
float单精度浮点型 4字节(32bit)0.0f
double双精度浮点型 8字节(64bit)0.0d
booleanjava未明确指出的大小(可能1bit、1byte、4byte)false
char字符型 2字节(16bit)空格

附:java的数据类型

解决BigDecimal转long丢失精度的问题

附:转换中的知识点

java中整数类型默认的int类型;小数类型默认的double;


*char 可以当做一 * 殊的整数类型;
*int无法转换为boolean;
*小数类型转为整数类型,小数可能被舍弃,所有出现精度损失,所以需要强制转换;
*boolean 类型不能转换成任何其它数据类型;
byte b2 = 120;
//没报错的原因:
//编译时候,进行检查,看赋值大小是否超过变量的类型所容纳的范围
//如果超过,报错:从int转换到byte可能会有损失,如果没超过,编译通过
float f3 = 100L; 这种情况,整数部分,可以直接赋值给float整数部分
float f1 = 100.9; 这种情况,因为默认的是double,如果这样转换,有可能失去小数点,必须强制转换
long l3 = 1000.9f; 小数转为整数,小数可能丢失,需要强制转换
double d2 = 10.9d;
int i2 = d2; //错误: 不兼容的类型: 从double转换到int可能会有损失
char c1 = 'a';
int i3 = c1; //自动转换
int i4 = 100;
//char c2 = i4;// 错误: 不兼容的类型: 从int转换到char可能会有损失

附:四则运算


/*
1、如果两个操作数中有一个是double类型,另一个就会转换为double类型;
2、否则,如果有一个操作数是float,另一个就会转化为float;
3、否则,如果有一个操作数是long,另一个就会转换为long;
4、否则,两个操作数都将转换为int类型。
*/

附:面试陷阱


byte b1 = 10;
byte b2 = 11;
//错误: 不兼容的类型: 从int转换到byte可能会有损失
//否则,两个操作数都将转换为int类型。
byte b3 = b1 + b2 //错误
byte b3 = (byte)(b1 + b2); //正确

short s1 = 1;
s1 = s1 + 1; //错误: 不兼容的类型: 从int转换到short可能会有损失

short s2 = 1;
s2 += 1; // 等同于short s2 = (short)(s2 + (short)1); //正确

附:从小到大顺序

解决BigDecimal转long丢失精度的问题

附:隐式转换、显式转换

当将占位数少的类型赋值给占位数多的类型时,java自动使用隐式类型转换(如int型转为long型)

当把在级别高的变量的值赋给级别低变量时,必须使用显式类型转换运算(如double型转为float型)

附:什么是不可变对象

不可变对象指对象一旦被创建,状态就不能再改变。任何修改都会创建一个新的对象,如String、Integer及其它包装类。

来源:https://www.cnblogs.com/zhouhao666/p/9994926.html

标签:BigDecimal,long,精度
0
投稿

猜你喜欢

  • Java内存模型中的虚拟机栈原理分析

    2022-02-08 04:41:33
  • ReentrantLock获取锁释放锁的流程示例分析

    2021-08-05 20:51:10
  • Android 程序执行Linux命令的解决方法及注意事项

    2023-07-13 00:14:58
  • MyBatis利用MyCat实现多租户的简单思路分享

    2022-08-16 18:58:33
  • 浅谈Java编程之if-else的优化技巧总结

    2023-06-02 23:28:12
  • 详解springboot测试类注解

    2023-06-04 21:04:37
  • 详解java基础--提示对话框的使用

    2023-01-31 12:11:46
  • 剑指Offer之Java算法习题精讲数组与字符串

    2021-05-24 19:21:45
  • Java Annotation(Java 注解)的实现代码

    2023-01-09 00:36:17
  • SpringBoot整合Apollo配置中心快速使用详解

    2022-12-25 17:00:34
  • 解析spring事务管理@Transactional为什么要添加rollbackFor=Exception.class

    2021-09-03 17:07:41
  • Java面向对象基础,类,变量,方法

    2023-04-08 13:21:49
  • Flutter加载图片流程之ImageCache源码示例解析

    2023-07-04 01:56:23
  • Mybatis拦 截 器实现数据权限的示例代码

    2023-11-19 20:15:04
  • java实现输入输出流代码分享

    2023-11-18 01:03:45
  • JAVA遍历一个文件夹中的所有文件的小例子

    2023-04-07 17:13:49
  • Java对象的XML序列化与反序列化实例解析

    2023-02-25 15:21:19
  • 图文浅析Java序列化和反序列化

    2022-08-03 17:46:59
  • 分享C#操作内存读写方法的主要实现代码

    2022-10-08 08:08:44
  • Logger.error打印错误异常的详细堆栈信息

    2022-01-06 23:03:04
  • asp之家 软件编程 m.aspxhome.com