博客
关于我
Java学习之旅(三九):大数字运算
阅读量:298 次
发布时间:2019-03-03

本文共 3335 字,大约阅读时间需要 11 分钟。

Java 中的大数字操作类

在 Java 中,处理大数字的计算任务可以借助 java.math.BigIntegerjava.math.BigDecimal 这两个高级类。BigInteger 主要用于处理大整数,而 BigDecimal 则专门用于处理带有小数点的大小数。

BigInteger 类

BigInteger 类能够处理任意精度的整数,能够处理远超 Integer 类型范围的数字。Integer 类型的最大值为 2^31 - 1,而 BigInteger 则没有数值大小的限制。

创建 BigInteger 实例

要创建 BigInteger 类的实例,可以通过字符串形式的数字来实现:

BigInteger value = new BigInteger("2");

需要注意的是,字符串参数必须使用双引号包裹。

常用操作

BigInteger 类提供了丰富的运算方法,包括加法、减法、乘法、除法等。以下是一些常用的方法示例:

  • 加法

    BigInteger add = bigInteger.add(new BigInteger("100"));
  • 减法

    BigInteger subtract = bigInteger.subtract(new BigInteger("50"));
  • 乘法

    BigInteger multiply = bigInteger.multiply(new BigInteger("1000"));
  • 除法

    BigInteger divide = bigInteger.divide(new BigInteger("20"));
  • 求余

    BigInteger remainder = bigInteger.remainder(new BigInteger("30"));
  • 次方运算

    BigInteger power = bigInteger.pow(4);
  • 取反数

    BigInteger negate = bigInteger.negate();
  • 位运算

    BigInteger leftShift = bigInteger.shiftLeft(2);BigInteger rightShift = bigInteger.shiftRight(3);
示例代码

以下是一个使用 BigInteger 类进行大整数运算的示例:

import java.math.BigInteger;public class BigIntegerDemo {    public static void main(String[] args) {        BigInteger bigInteger = new BigInteger("100");                System.out.println("加法运算:" + bigInteger.add(new BigInteger("100")));        System.out.println("减法运算:" + bigInteger.subtract(new BigInteger("50")));        System.out.println("乘法运算:" + bigInteger.multiply(new BigInteger("1000")));        System.out.println("除法运算:" + bigInteger.divide(new BigInteger("20")));        System.out.println("求余运算:" + bigInteger.remainder(new BigInteger("30")));        System.out.println("次方运算:" + bigInteger.pow(4));        System.out.println("取反数运算:" + bigInteger.negate());        System.out.println("左移运算:" + bigInteger.shiftLeft(2));        System.out.println("右移运算:" + bigInteger.shiftRight(3));    }}

BigDecimal 类

BigDecimal 类用于处理带有小数点的大小数,支持任意精度的定点数计算。常见于货币计算和科学计算。

创建 BigDecimal 实例

可以通过字符串或双精度浮点数来创建 BigDecimal 实例:

BigDecimal bigDecimal = new BigDecimal("123.45");// 或者BigDecimal bigDecimal = new BigDecimal(123.45);
常用操作

BigDecimal 类的运算方法与 BigInteger 类类似,支持加法、减法、乘法和除法等操作。需要注意的是,除法操作需要指定舍入模式。

  • 加法

    BigDecimal add = bigDecimal.add(new BigDecimal("10"));
  • 减法

    BigDecimal subtract = bigDecimal.subtract(new BigDecimal("5"));
  • 乘法

    BigDecimal multiply = bigDecimal.multiply(new BigDecimal("2.5"));
  • 除法

    BigDecimal divide = bigDecimal.divide(new BigDecimal("4"), 2, BigDecimal.ROUND_HALF_UP);
舍入模式

BigDecimal 类提供多种舍入模式,常用的有:

  • BigDecimal.ROUND_UP:如果商的最后一位数字大于0,则进位。
  • BigDecimal.ROUND_DOWN:总是舍去最后一位数字。
  • BigDecimal.ROUND_CEILING:向上取整。
  • BigDecimal.ROUND_FLOOR:向下取整。
  • BigDecimal.ROUND_HALF_UP:四舍五入。
  • BigDecimal.ROUND_HALF_DOWN:四舍五入,且如果最后一位是5则舍去。
示例代码

以下是一个使用 BigDecimal 类进行大小数运算的示例:

import java.math.BigDecimal;public class BigDecimalDemo {    public static void main(String[] args) {        BigDecimal bigDecimal = new BigDecimal("123.45");                System.out.println("加法运算:" + bigDecimal.add(new BigDecimal("10.5")));        System.out.println("减法运算:" + bigDecimal.subtract(new BigDecimal("5.5")));        System.out.println("乘法运算:" + bigDecimal.multiply(new BigDecimal("2.5")));        System.out.println("除法运算(舍入到两位小数):" + bigDecimal.divide(new BigDecimal("4"), 2, BigDecimal.ROUND_HALF_UP));    }}

总结

BigIntegerBigDecimal 类为 Java 提供了强大的大数字处理能力。BigInteger 专注于处理大整数,而 BigDecimal 则扩展了支持范围,能够处理精确到任意小数位的定点数。在实际应用中,可以根据需求选择合适的类来进行数值计算,确保计算的准确性和效率。

转载地址:http://wevm.baihongyu.com/

你可能感兴趣的文章
null可以转换成任意非基本类型(int/short/long/float/boolean/byte/double/char以外)
查看>>
Number Sequence(kmp算法)
查看>>
Numix Core 开源项目教程
查看>>
numpy
查看>>
NumPy 库详细介绍-ChatGPT4o作答
查看>>
NumPy 或 Pandas:将数组类型保持为整数,同时具有 NaN 值
查看>>
numpy 或 scipy 有哪些可能的计算可以返回 NaN?
查看>>
numpy 数组 dtype 在 Windows 10 64 位机器中默认为 int32
查看>>
numpy 数组与矩阵的乘法理解
查看>>
NumPy 数组拼接方法-ChatGPT4o作答
查看>>
numpy 用法
查看>>
Numpy 科学计算库详解
查看>>
Numpy.fft.fft和numpy.fft.fftfreq有什么不同
查看>>
Numpy.ndarray对象不可调用
查看>>
Numpy.VisibleDeproationWarning:从不整齐的嵌套序列创建ndarray
查看>>
Numpy:按多个条件过滤行?
查看>>
Numpy:条件总和
查看>>
numpy、cv2等操作图片基本操作
查看>>
numpy中的argsort的用法
查看>>
NumPy中的精度:比较数字时的问题
查看>>