Java.math.BigDecimal类


java.math.BigDecimal 类提供用于算术,刻度操作,舍入,比较,哈希算法和格式转换操作。

toString()方法提供BigDecimal的规范表示。它使用户可以完全控制舍入行为。

提供用于操作BigDecimal规模两种类型的操作:

  • 缩放/舍入操作

  • 小数点移动操作。

此类及其迭代器实现Comparable接口的所有可选方法。

类声明

以下是声明java.math.BigDecimal类:

public class BigDecimal
    extends Number
        implements Comparable<BigDecimal>

字段域

以下是java.math.BigDecimal类中的字段:

  • static BigDecimal ONE -- 值为1,使用刻度为0。

  • static int ROUND_CEILING -- 舍入模式舍向正无穷。

  • static int ROUND_DOWN -- 舍入模式为向零舍入。

  • static int ROUND_FLOOR -- 舍入模式接近负无穷大。

  • static int ROUND_HALF_DOWN -- 舍入模式舍入到“最近相邻”如果与两个相邻数字的距离相等,在这种情况下,向下取整。

  • static int ROUND_HALF_EVEN --  舍入模式舍对“近邻”如果与两个相邻数字的距离相等,在这种情况下,舍入向着更加相邻。

  • static int ROUND_HALF_UP -- 舍入模式舍入到“最近相邻”如果与两个相邻数字的距离相等,在这种情况下范围。

  • static int ROUND_UNNECESSARY -- 舍入模式断言请求的操作具有精确的结果,因此不需要舍入。

  • static int ROUND_UP -- 舍入模式舍入去零。

  • static BigDecimal TEN -- 值为0,使用刻度为0。

  • static BigDecimal ZERO -- 值为0,使用刻度为0。

类构造函数

S.N.构造函数 & 描述
1BigDecimal(BigInteger val)
这个构造函数是用来将BigInteger转换为BigDecimal。
2BigDecimal(BigInteger unscaledVal, int scale)
这个构造函数用于转换为BigInteger非标度值和一个int尺度成一个BigDecimal。
3BigDecimal(BigInteger unscaledVal, int scale, MathContext mc)
这个构造函数用于转换为BigInteger非标度值和一个int尺度转换为BigDecimal,有根据上下文设置进行舍入。
4BigDecimal(BigInteger val, MathContext mc)
此构造函数用于根据上下文设置将BigInteger转换为BigDecimal舍入。
5BigDecimal(char[ ] in)
此构造函数用于将BigDecimal字符数组表示转化为BigDecimal,接受相同的字符序列与BigDecimal(String)构造函数。
6BigDecimal(char[ ] in, int offset, int len)
此构造函数用于将BigDecimal的字符数组表示转化为BigDecimal,接受字符与BigDecimal(String)构造方法相同的字符序列,同时允许指定子数组。
7BigDecimal(char[ ] in, int offset, int len, MathContext mc)
此构造函数用于将BigDecimal的字符数组表示转化为BigDecimal,接受字符与BigDecimal(String)构造方法相同的字符序列,同时允许指定子数组,并与根据上下文设置进行舍入。
8BigDecimal(char[ ] in, MathContext mc)
此构造函数用于将BigDecimal的字符数组表示转化为BigDecimal,接受相同的字符序列与BigDecimal(String)构造和根据上下文设置进行舍入。
9BigDecimal(double val)
这个构造函数是用来转换double为一个BigDecimal,它是双的二进制浮点值的精确十进制表示。
10BigDecimal(double val, MathContext mc)
这个构造函数是用来转换double为一个BigDecimal,有根据上下文设置进行舍入。
11BigDecimal(int val)
这个构造函数是用来转换一个int转换为BigDecimal。
12BigDecimal(int val, MathContext mc)
这个构造函数是用来转换一个int转换为BigDecimal,有根据上下文设置进行舍入。
13BigDecimal(long val)
这个构造函数用于转换long为一个BigDecimal。
14BigDecimal(long val, MathContext mc)
这个构造函数是将BigInteger转换为BigDecimal。
15BigDecimal(String val)
此构造函数用于一个BigDecimal的字符串表示形式转换为BigDecimal。
16BigDecimal(String val, MathContext mc)
此构造函数用于将BigDecimal的字符串表示形式转换为BigDecimal,接受相同的字符串作为与BigDecimal(String)构造,并根据上下文设置进行舍入。

类方法

S.N.方法 & 描述
1BigDecimal abs() 
此方法返回一个BigDecimal,其值是此BigDecimal的绝对值,其标度是this.scale()。
2BigDecimal abs(MathContext mc) 
此方法返回一个BigDecimal,其值是此BigDecimal的绝对值,与根据上下文设置进行舍入。
3BigDecimal add(BigDecimal augend)
此方法返回一个BigDecimal,其值为(this + augend),其标度为max(this.scale(), augend.scale())。
4BigDecimal add(BigDecimal augend, MathContext mc) 
此方法返回一个BigDecimal,其值为 (this + augend),与根据上下文设置进行舍入。
5byte byteValueExact() 
这种方法的BigDecimal转换为一个字节,检查丢失的信息。
6int compareTo(BigDecimal val) 
这种方法比较BigDecimal与指定的BigDecimal。
7BigDecimal divide(BigDecimal divisor)
此方法返回一个BigDecimal,其值为(this/除数),且其首选标度为(this.scale() - divisor.scale());如果准确的商不能表示(因为它有无穷的十进制扩展),则抛出ArithmeticException。 
8BigDecimal divide(BigDecimal divisor, int roundingMode)
此方法返回一个BigDecimal,其值为(this/除数),其标度是this.scale()。
9BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)
此方法返回一个BigDecimal,其值为(this/除数),其标度如指定。
10BigDecimal divide(BigDecimal divisor, int scale, RoundingMode roundingMode) 
此方法返回一个BigDecimal,其值为(this/除数),其标度为指定。
11BigDecimal divide(BigDecimal divisor, MathContext mc) 
此方法返回一个BigDecimal,其值为(this/除数),与根据上下文设置进行舍入。
12BigDecimal divide(BigDecimal divisor, RoundingMode roundingMode)
此方法返回一个BigDecimal,其值为(this/除数),其标度是this.scale()。
13BigDecimal[ ] divideAndRemainder(BigDecimal divisor)
这个方法返回一个包含divideToIntegralValue结果,其次是剩下的两个操作数的结果的结果由两个元素组成的BigDecimal数组。
14BigDecimal[ ] divideAndRemainder(BigDecimal divisor, MathContext mc) 
这个方法返回一个包含divideToIntegralValue的结果,随后其余与上根据上下文设置进行舍入计算两个操作数的结果的结果由两个元素组成的BigDecimal数组。
15BigDecimal divideToIntegralValue(BigDecimal divisor) 
此方法返回一个BigDecimal,其值为商(这/除数)的整数部分四舍五入。
16BigDecimal divideToIntegralValue(BigDecimal divisor, MathContext mc)
此方法返回一个BigDecimal,其值是(这/除数)的整数部分。
17double doubleValue() 
此方法将BigDecimal转换为double。
18boolean equals(Object x) 
这种方法比较BigDecimal与指定对象是否相等。
19float floatValue()
这种方法将BigDecimal转换为float。
20int hashCode() 
此方法返回BigDecimal的哈希代码。
21int intValue()
这种方法将BigDecimal转换为int。
22int intValueExact()
这种方法将BigDecimal转换为int,检查丢失的信息。
23long longValue()
这种方法将BigDecimal转换为long。
24long longValueExact()
这种方法将BigDecimal转换为long,检查丢失的信息。
25BigDecimal max(BigDecimal val)
此方法返回此BigDecimal和val的最大值。
26BigDecimal min(BigDecimal val)
此方法返回此BigDecimal和val的最小值。
27BigDecimal movePointLeft(int n)
此方法返回一个BigDecimal,它等效于将该值的小数点移动n位到左边。
28BigDecimal movePointRight(int n) 
此方法返回一个BigDecimal,它等效于将该值的小数点移动n位到右边。
29BigDecimal multiply(BigDecimal multiplicand)
此方法返回一个BigDecimal,其值为(this×被乘数),其标度为(this.scale()+ multiplicand.scale())。
30BigDecimal multiply(BigDecimal multiplicand, MathContext mc)
此方法返回一个BigDecimal,其值为(this×乘数),以根据上下文设置进行舍入。
31BigDecimal negate()
此方法返回一个BigDecimal,其值是(+this),其标度是this.scale()。
32BigDecimal negate(MathContext mc)
此方法返回一个BigDecimal,其值是(-this),根据上下文设置进行舍入。
33BigDecimal plus() 
此方法返回一个BigDecimal,其值是(+this),其标度是this.scale()。
34BigDecimal plus(MathContext mc) 
此方法返回一个BigDecimal,其值是(+this),根据上下文设置进行舍入。
35BigDecimal pow(int n) 
此方法返回一个BigDecimal,其值是(thisn), 幂被精确计算,使其具有无限精度。
36BigDecimal pow(int n, MathContext mc)
此方法返回一个BigDecimal,其值是 (thisn).
37int precision() 
此方法返回此BigDecimal的精度。
38BigDecimal remainder(BigDecimal divisor) 
此方法将BigDecimal转换为一个byte,检查丢失的信息。
39BigDecimal remainder(BigDecimal divisor, MathContext mc)
此方法返回一个BigDecimal,其值为(this%除数),根据上下文设置进行舍入。
40BigDecimal round(MathContext mc) 
此方法返回根据MathContext设置舍入一个BigDecimal。
41int scale() 
此方法返回此BigDecimal的标度。
42BigDecimal scaleByPowerOfTen(int n) 
此方法返回一个BigDecimal,其数值等于 (this * 10n).
43BigDecimal setScale(int newScale)
此方法返回一个BigDecimal,其标度为指定值,其值在数值上等于该BigDecimal。
44BigDecimal setScale(int newScale, int roundingMode) 
此方法返回一个BigDecimal,其标度为指定值,其非标度值乘以或除以此BigDecimal的非标度值除以十的次幂,以保持其整体值决定。
45BigDecimal setScale(int newScale, RoundingMode roundingMode) 
此方法返回一个BigDecimal,其标度为指定值,其非标度值乘以或除以此BigDecimal的非标度值除以十的次幂,以保持其整体价决定。
46short shortValueExact()
这种方法将BigDecimal转换为short,检查丢失的信息。
47int signum()
此方法返回此BigDecimal的正负号函数。
48BigDecimal stripTrailingZeros() 
此方法返回一个BigDecimal,它在数值上等于这一个,但与从表示形式移除所有尾部零。
49BigDecimal subtract(BigDecimal subtrahend) 
此方法返回一个BigDecimal,其值为(this - 减数),其标度为max(this.scale(),subtrahend.scale())。
50BigDecimal subtract(BigDecimal subtrahend, MathContext mc) 
此方法返回一个BigDecimal,其值为(this - 减数),与根据上下文设置进行舍入。
51BigInteger toBigInteger() 
这种方法将BigDecimal转换为BigInteger。
52BigInteger toBigIntegerExact()
这种方法将BigDecimal转换为BigInteger,检查丢失的信息。
53String toEngineeringString() 
此方法返回此BigDecimal的字符串表示形式,使用工程计数法,如果需要指数。
54String toPlainString() 
此方法返回此BigDecimal的字符串表示形式不带指数字段。
55String toString()
此方法返回此BigDecimal的字符串表示形式,用科学记数法,如果需要指数。
56BigDecimal ulp()
此方法返回一个ULP的此BigDecimal的大小,在最后一位的单位。
57BigInteger unscaledValue()
此方法返回一个BigInteger,其值是此BigDecimal的非标度值。
58static BigDecimal valueOf(double val) 
这种方法转换double为一个BigDecimal,使用Double.toString(double)方法提供的double的规范化字符串表示形式。
59static BigDecimal valueOf(long val)
这种方法将一个long值转换为BigDecimal带有刻度的零值。
60static BigDecimal valueOf(long unscaledVal, int scale)
这种方法转换long的非标度值和一个int尺度成一个BigDecimal。


分类导航
点击按住视频可拖动

缩小

关闭

  • 北京总部地址:北京市海淀区西三旗桥东建材城西路85号神州科技园B座三层尚学堂
  • 咨询电话:400-009-1906 010-56233821
  • Copyright 2007-2015 北京尚学堂科技有限公司
  • 京ICP备13018289号-1 京公网安备11010802015183