BigDecimal与BigInteger用法(Java)
2024-01-07 17:23:17
BigDecimal与BigInteger用法
1. BigDecimal(处理高精度小数运算的类)
BigDecimal 是 Java 中用于处理高精度小数运算的类,它可以处理任意位数的小数,避免了浮点数运算中可能出现的精度误差问题。在 Java 应用程序中,如果需要进行高精度小数运算,就可以使用 BigDecimal 类。
下面是 BigDecimal 类的常用方法:
- 创建 BigDecimal 对象
可以使用以下方式创建 BigDecimal 对象:
// 使用字符串来创建 BigDecimal 对象
BigDecimal num1 = new BigDecimal("123.45");
BigDecimal num2 = new BigDecimal("67.89");
// 使用 double 或 float 类型来创建 BigDecimal 对象
BigDecimal num3 = new BigDecimal(123.45);
BigDecimal num4 = new BigDecimal(67.89f);
// 使用 long 或 int 类型来创建 BigDecimal 对象
BigDecimal num5 = new BigDecimal(12345);
BigDecimal num6 = new BigDecimal(6789L);
- 进行加、减、乘、除运算
可以使用以下方法进行加、减、乘、除等运算:
BigDecimal sum = num1.add(num2); // 加法运算
BigDecimal diff = num1.subtract(num2); // 减法运算
BigDecimal product = num1.multiply(num2); // 乘法运算
BigDecimal quotient = num1.divide(num2, 2, RoundingMode.HALF_UP); // 除法运算,结果保留两位小数,四舍五入
需要注意的是,除法运算时,如果除不尽会抛出异常。因此,在进行除法运算时,需要指定小数位数和舍入方式。
- 比较大小
可以使用以下方法比较两个 BigDecimal 对象的大小:
int cmp = num1.compareTo(num2); // 比较大小,返回值为 -1、0、1 分别表示小于、等于、大于
boolean b1 = num1.equals(num2); // 判断是否相等
boolean b2 = num1.compareTo(num2) > 0; // 判断大小关系
- 转换为其他数据类型
可以使用以下方法将 BigDecimal 对象转换为其他数据类型:
double d = num1.doubleValue(); // 转换为 double 类型
float f = num1.floatValue(); // 转换为 float 类型
long l = num1.longValue(); // 转换为 long 类型
int i = num1.intValue(); // 转换为 int 类型
String s = num1.toString(); // 转换为字符串类型
需要注意的是,在将 BigDecimal 对象转换为基本数据类型时,可能会丢失精度,因此需要谨慎处理。
2.BigInteger(处理高精度整数运算的类)
BigInteger 是 Java 中用于处理高精度整数运算的类,它可以处理任意位数的整数,避免了整数溢出的问题。在 Java 应用程序中,如果需要进行高精度整数运算,就可以使用 BigInteger 类。
下面是 BigInteger 类的常用方法:
- 创建 BigInteger 对象
可以使用以下方式创建 BigInteger 对象:
// 使用字符串来创建 BigInteger 对象
BigInteger num1 = new BigInteger("12345678901234567890");
BigInteger num2 = new BigInteger("-12345678901234567890");
// 使用 long 或 int 类型来创建 BigInteger 对象
BigInteger num3 = BigInteger.valueOf(1234567890L);
BigInteger num4 = BigInteger.valueOf(-1234567890);
需要注意的是,使用 long 或 int 类型来创建 BigInteger 对象时,可能会发生溢出,因此需要谨慎处理。
- 进行加、减、乘、除运算
可以使用以下方法进行加、减、乘、除等运算:
BigInteger sum = num1.add(num2); // 加法运算
BigInteger diff = num1.subtract(num2); // 减法运算
BigInteger product = num1.multiply(num2); // 乘法运算
BigInteger quotient = num1.divide(num2); // 除法运算
BigInteger remainder = num1.remainder(num2); // 取余运算
需要注意的是,在进行除法运算时,如果除不尽会抛出异常。因此,在进行除法运算时,需要谨慎处理。
- 比较大小
可以使用以下方法比较两个 BigInteger 对象的大小:
int cmp = num1.compareTo(num2); // 比较大小,返回值为 -1、0、1 分别表示小于、等于、大于
boolean b1 = num1.equals(num2); // 判断是否相等
boolean b2 = num1.compareTo(num2) > 0; // 判断大小关系
- 转换为其他数据类型
可以使用以下方法将 BigInteger 对象转换为其他数据类型:
long l = num1.longValue(); // 转换为 long 类型
int i = num1.intValue(); // 转换为 int 类型
String s = num1.toString(); // 转换为字符串类型
需要注意的是,在将 BigInteger 对象转换为基本数据类型时,可能会发生溢出,因此需要谨慎处理。
文章来源:https://blog.csdn.net/weixin_48935611/article/details/135436891
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!