java中大数的计算BigInteger和BigDecimal两个类的常用方法

简介: java中大数的计算BigInteger和BigDecimal两个类的常用方法

1、BigInteger

Modifier and Type Method and Description
BigInteger abs()

返回一个BigInteger,它的值是此BigInteger的绝对值。

BigInteger add(BigInteger val)

返回值为 (this + val)

BigInteger and(BigInteger val)

返回值为 (this & val)

BigInteger andNot(BigInteger val)

返回值为 (this & ~val)

int bitCount()

返回与其符号位不同的BigInteger的二进制补码表示中的位数。

int bitLength()

返回此BigInteger的最小二进制补码表示中的位数, 包括符号位。

byte byteValueExact()

将此 BigInteger转换为 byte ,检查丢失的信息。

BigInteger clearBit(int n)

返回一个BigInteger,其值等于此BigInteger,指定的位被清零。

int compareTo(BigInteger val)

将此BigInteger与指定的BigInteger进行比较。

BigInteger divide(BigInteger val)

返回值为 (this / val)

BigInteger[] divideAndRemainder(BigInteger val)

返回两个BigInteger的数组,其中包含 (this / val)后跟 (this % val)

double doubleValue()

将此BigInteger转换为 double

boolean equals(Object x)

将此BigInteger与指定的对象进行比较以实现相等。

BigInteger flipBit(int n)

返回一个BigInteger,其值等于此BigInteger,指定的位被翻转。

float floatValue()

将此BigInteger转换为 float

BigInteger gcd(BigInteger val)

返回一个BigInteger,其值是 abs(this)abs(val)

int getLowestSetBit()

返回此BigInteger中最右(最低位)一位的索引(最右边一位右侧的零位数)。

int hashCode()

返回此BigInteger的哈希码。

int intValue()

将此BigInteger转换为 int

int intValueExact()

将此 BigInteger转换为 int ,检查丢失的信息。

boolean isProbablePrime(int certainty)

返回 true如果这个BigInteger可能是素数, false如果它是绝对复合。

long longValue()

将此BigInteger转换为 long

long longValueExact()

将此 BigInteger转换为 long ,检查丢失的信息。

BigInteger max(BigInteger val)

返回此BigInteger和 val

BigInteger min(BigInteger val)

返回此BigInteger和 val

BigInteger mod(BigInteger m)

返回值为 (this mod m )。

BigInteger modInverse(BigInteger m)

返回值为 (this-1mod m)

BigInteger modPow(BigInteger exponent, BigInteger m)

返回值为 (thisexponent mod m)的BigInteger 。

BigInteger multiply(BigInteger val)

返回值为 (this * val)

BigInteger negate()

返回值为 (-this)

BigInteger nextProbablePrime()

返回大于这个 BigIntegerBigInteger的第一个整数。

BigInteger not()

返回值为 (~this)

BigInteger or(BigInteger val)

返回值为 (this | val)

BigInteger pow(int exponent)

返回值为 (thisexponent)的BigInteger 。

static BigInteger probablePrime(int bitLength, Random rnd)

返回一个正的BigInteger,它可能是素数,具有指定的位长度。

BigInteger remainder(BigInteger val)

返回值为 (this % val)

BigInteger setBit(int n)

返回一个BigInteger,其值等于具有指定位集合的BigInteger。

BigInteger shiftLeft(int n)

返回值为 (this << n)

BigInteger shiftRight(int n)

返回值为 (this >> n)

short shortValueExact()

将此 BigInteger转换为 short ,检查丢失的信息。

int signum()

返回此BigInteger的signum函数。

BigInteger subtract(BigInteger val)

返回值为 (this - val)

boolean testBit(int n)

返回 true当且仅当指定的位被设置。

byte[] toByteArray()

返回一个包含此BigInteger的二进制补码表示的字节数组。

String toString()

返回此BigInteger的十进制字符串表示形式。

String toString(int radix)

返回给定基数中BigInteger的String表示形式。

static BigInteger valueOf(long val)

返回一个BigInteger,其值等于指定的 long

BigInteger xor(BigInteger val)

返回值为 (this ^ val)

2、BigDecimal

Modifier and Type Method and Description
BigDecimal abs()

返回一个 BigDecimal ,其值为此 BigDecimal的绝对值,其缩放比例为 this.scale()

BigDecimal abs(MathContext mc)

返回一个 BigDecimal ,其值为此 BigDecimal的绝对值,根据上下文设置进行舍入。

BigDecimal add(BigDecimal augend)

返回 BigDecimal ,其值是 (this + augend) ,其标为 max(this.scale(), augend.scale())

BigDecimal add(BigDecimal augend, MathContext mc)

返回 BigDecimal ,其值是 (this + augend) ,根据上下文设置进行舍入。

byte byteValueExact()

将此 BigDecimal转换为 byte ,检查丢失的信息。

int compareTo(BigDecimal val)

将此 BigDecimal与指定的BigDecimal进行 BigDecimal

BigDecimal divide(BigDecimal divisor)

返回BigDecimal ,其值为(this / divisor) ,优先级为(this.scale() - divisor.scale()) ; 如果不能表示确切的商(因为它具有非终止的十进制扩展),则抛出一个ArithmeticException

BigDecimal divide(BigDecimal divisor, int roundingMode)

返回 BigDecimal ,其值是 (this / divisor) ,其标为 this.scale()

BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)

返回一个 BigDecimal ,其值为 (this / divisor) ,其比例为指定。

BigDecimal divide(BigDecimal divisor, int scale, RoundingMode roundingMode)

返回一个 BigDecimal ,其值为 (this / divisor) ,其比例为指定。

BigDecimal divide(BigDecimal divisor, MathContext mc)

返回 BigDecimal ,其值是 (this / divisor) ,根据上下文设置进行舍入。

BigDecimal divide(BigDecimal divisor, RoundingMode roundingMode)

返回 BigDecimal ,其值是 (this / divisor) ,其标为 this.scale()

BigDecimal[] divideAndRemainder(BigDecimal divisor)

返回一个两元件 BigDecimal阵列含有的结果 divideToIntegralValue接着的结果 remainder上的两个操作数。

BigDecimal[] divideAndRemainder(BigDecimal divisor, MathContext mc)

返回一个两元件 BigDecimal阵列含有的结果 divideToIntegralValue接着的结果 remainder上与根据上下文设置进行舍入计算出的两个操作数。

BigDecimal divideToIntegralValue(BigDecimal divisor)

返回一个 BigDecimal ,它的值是 BigDecimal的整数部分 (this / divisor)取整。

BigDecimal divideToIntegralValue(BigDecimal divisor, MathContext mc)

返回值为 BigDecimal的整数部分的 (this / divisor)

double doubleValue()

将此 BigDecimal转换为 double

boolean equals(Object x)

将此 BigDecimal与指定的 Object进行比较以获得相等性。

float floatValue()

将此 BigDecimal转换为 float

int hashCode()

返回此 BigDecimal的哈希码。

int intValue()

将此 BigDecimal转换为 int

int intValueExact()

将此 BigDecimal转换为 int ,检查丢失的信息。

long longValue()

将此 BigDecimal转换为 long

long longValueExact()

将此 BigDecimal转换为 long ,检查丢失的信息。

BigDecimal max(BigDecimal val)

返回此 BigDecimalval

BigDecimal min(BigDecimal val)

返回此 BigDecimalval

BigDecimal movePointLeft(int n)

返回一个 BigDecimal ,相当于这个小数点,向左移动了 n个地方。

BigDecimal movePointRight(int n)

返回一个 BigDecimal ,相当于这个小数点移动了 n个地方。

BigDecimal multiply(BigDecimal multiplicand)

返回 BigDecimal ,其值是 (this × multiplicand),其标为 (this.scale() + multiplicand.scale())

BigDecimal multiply(BigDecimal multiplicand, MathContext mc)

返回 BigDecimal ,其值是 (this × multiplicand),根据上下文设置进行舍入。

BigDecimal negate()

返回 BigDecimal ,其值是 (-this) ,其标为 this.scale()

BigDecimal negate(MathContext mc)

返回 BigDecimal ,其值是 (-this) ,根据上下文设置进行舍入。

BigDecimal plus()

返回 BigDecimal ,其值是 (+this) ,其标为 this.scale()

BigDecimal plus(MathContext mc)

返回 BigDecimal ,其值是 (+this) ,根据上下文设置进行舍入。

BigDecimal pow(int n)

返回 BigDecimal ,其值是 (thisn),该电源,准确计算,使其具有无限精度。

BigDecimal pow(int n, MathContext mc)

返回 BigDecimal ,其值是 (thisn)。

int precision()

返回此 BigDecimalBigDecimal

BigDecimal remainder(BigDecimal divisor)

返回 BigDecimal ,其值是 (this % divisor)

BigDecimal remainder(BigDecimal divisor, MathContext mc)

返回 BigDecimal ,其值是 (this % divisor) ,根据上下文设置进行舍入。

BigDecimal round(MathContext mc)

返回 BigDecimal根据四舍五入 MathContext设置。

int scale()

返回此 规模BigDecimal

BigDecimal scaleByPowerOfTen(int n)

返回一个BigDecimal,其数值等于( this * 10 n )。

BigDecimal setScale(int newScale)

返回一个 BigDecimal ,其大小是指定值,其值在数字上等于此 BigDecimal

BigDecimal setScale(int newScale, int roundingMode)

返回一个 BigDecimal ,其规模是指定值,其缩放值通过将此 BigDecimal的非标度值乘以10的适当功率来确定,以维持其总体值。

BigDecimal setScale(int newScale, RoundingMode roundingMode)

返回一个 BigDecimal ,其规模是指定值,其缩放值通过将该 BigDecimal的非标度值乘以10的适当功率来确定,以维持其整体值。

short shortValueExact()

将此 BigDecimal转换为 short ,检查丢失的信息。

int signum()

返回这个 BigDecimal的signum函数。

BigDecimal stripTrailingZeros()

返回一个 BigDecimal ,它在数字上等于此值, BigDecimal表示中删除任何尾随的零。

BigDecimal subtract(BigDecimal subtrahend)

返回 BigDecimal ,其值是 (this - subtrahend) ,其标为 max(this.scale(), subtrahend.scale())

BigDecimal subtract(BigDecimal subtrahend, MathContext mc)

返回 BigDecimal ,其值是 (this - subtrahend) ,根据上下文设置进行舍入。

BigInteger toBigInteger()

将此 BigDecimal转换为 BigInteger

BigInteger toBigIntegerExact()

将此 BigDecimal转换为 BigInteger ,检查丢失的信息。

String toEngineeringString()

如果需要指数,则使用工程符号返回此 BigDecimal的字符串表示形式。

String toPlainString()

返回没有指数字段的此 BigDecimal的字符串表示形式。

String toString()

返回此 BigDecimal的字符串表示,如果需要指数,则使用科学计数法。

BigDecimal ulp()

返回此 BigDecimal的最后一个位置的ulp(一个单位)的大小。

BigInteger unscaledValue()

返回一个 BigInteger ,其值是此 BigDecimal未缩放值

static BigDecimal valueOf(double val)

转换一个 doubleBigDecimal ,使用 double通过所提供的规范的字符串表示 Double.toString(double)方法。

static BigDecimal valueOf(long val)

long值转换为 BigDecimal ,比例为零。

static BigDecimal valueOf(long unscaledVal, int scale)

long值和 int比例转换为 BigDecimal

目录
相关文章
|
22天前
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
|
28天前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
67 9
|
21天前
|
安全 Java 开发者
Java中WAIT和NOTIFY方法必须在同步块中调用的原因
在Java多线程编程中,`wait()`和`notify()`方法是实现线程间协作的关键。这两个方法必须在同步块或同步方法中调用,这一要求背后有着深刻的原因。本文将深入探讨为什么`wait()`和`notify()`方法必须在同步块中调用,以及这一机制如何确保线程安全和避免死锁。
35 4
|
21天前
|
Java
深入探讨Java中的中断机制:INTERRUPTED和ISINTERRUPTED方法详解
在Java多线程编程中,中断机制是协调线程行为的重要手段。了解和正确使用中断机制对于编写高效、可靠的并发程序至关重要。本文将深入探讨Java中的`Thread.interrupted()`和`Thread.isInterrupted()`方法的区别及其应用场景。
24 4
|
18天前
|
Java 数据处理 数据安全/隐私保护
Java处理数据接口方法
Java处理数据接口方法
23 1
|
2月前
|
Java API
Java 对象释放与 finalize 方法
关于 Java 对象释放的疑惑解答,以及 finalize 方法的相关知识。
50 17
|
1月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
106 4
|
1月前
|
Java 测试技术 Maven
Java一分钟之-PowerMock:静态方法与私有方法测试
通过本文的详细介绍,您可以使用PowerMock轻松地测试Java代码中的静态方法和私有方法。PowerMock通过扩展Mockito,提供了强大的功能,帮助开发者在复杂的测试场景中保持高效和准确的单元测试。希望本文对您的Java单元测试有所帮助。
133 2
|
2月前
|
Java 开发者
在Java多线程编程中,选择合适的线程创建方法至关重要
【10月更文挑战第20天】在Java多线程编程中,选择合适的线程创建方法至关重要。本文通过案例分析,探讨了继承Thread类和实现Runnable接口两种方法的优缺点及适用场景,帮助开发者做出明智的选择。
22 2
|
1月前
|
Java Spring
JAVA获取重定向地址URL的两种方法
【10月更文挑战第17天】本文介绍了两种在Java中获取HTTP响应头中的Location字段的方法:一种是使用HttpURLConnection,另一种是使用Spring的RestTemplate。通过设置连接超时和禁用自动重定向,确保请求按预期执行。此外,还提供了一个自定义的`NoRedirectSimpleClientHttpRequestFactory`类,用于禁用RestTemplate的自动重定向功能。