数学相关类
数学相关类
1. BigDecimal
- 一般的Float类和Double类可以用来做科学计算或工程计算,但在商业计算中,要求数字精度比较高,故用到java.math.BigDecimal类。
BigDecimal
类支持不可变的、任意精度的有符号十进制定点数。
构造器
BigDecimal(double val)
BigDecimal(String val)
:推荐使用。
常用方法
BigDecimal add(BigDecimal augend)
:加BigDecimal subtract(BigDecimal subtrahend)
:减BigDecimal multiply(BigDecimal multiplicand)
:乘BigDecimal divide(BigDecimal divisor, int scale, int roundingMode
):除divisor
是除数scale
指明保留几位小数roundingMode
指明舍入模式- (
ROUND_UP
:向上加1、ROUND_DOWN
:直接舍去、ROUND_HALF_UP
:四舍五入)
- (
BigInteger bi = new BigInteger("12433241123"); |
2. BigInteger
java.math
包的BigInteger
可以表示不可变的任意精度的整数。BigInteger 提供所有 Java 的基本整数操作符的对应物,并提供 java.lang.Math 的所有相关方法。- 另外,BigInteger 还提供以下运算:模算术、GCD 计算、质数测试、素数生成、位操作以及一些其他操作。
构造器
BigInteger(String val)
:根据字符串构建BigInteger对象
常用方法
BigInteger abs()
:返回此 BigInteger 的绝对值的 BigInteger。BigInteger add(BigInteger val)
:返回其值为 (this + val) 的 BigIntegerBigInteger subtract(BigInteger val)
:返回其值为 (this - val) 的 BigIntegerBigInteger multiply(BigInteger val)
:返回其值为 (this * val) 的 BigIntegerBigInteger divide(BigInteger val)
:返回其值为 (this / val) 的 BigInteger。整数相除只保留整数部分。BigInteger remainder(BigInteger val)
:返回其值为 (this % val) 的 BigInteger。BigInteger[] divideAndRemainder(BigInteger val)
:返回包含 (this / val) 后跟 (this % val) 的两个 BigInteger 的数组。BigInteger pow(int exponent)
:返回其值为 (this^exponent) 的 BigInteger。
//long bigNum = 123456789123456789123456789L; |
3. Math
java.lang.Math
类包含用于执行基本数学运算的方法,如初等指数、对数、平方根和三角函数。类似这样的工具类,其所有方法均为静态方法,并且不会创建对象,调用起来非常简单。
常用属性
double PI
:返回圆周率(public static final
)double E
:返回e
,即2.71828…(public static final
)
常用方法
double abs(double a)
:返回 double 值的绝对值。double ceil(double a)
:返回大于等于参数的最小的整数。double floor(double a)
:返回小于等于参数最大的整数。long round(double a)
:返回最接近参数的 long(相当于四舍五入方法) 。- 等价于
floor(a + 0.5)
,即中间值时取较大的一边。
- 等价于
double pow(double a,double b)
:返回a的b幂次方法。double sqrt(double a)
:返回a的平方根。double random()
:返回[0,1)的随机值。double max(double x, double y)
:返回x,y中的最大值。double min(double x, double y)
:返回x,y中的最小值。
以上方法皆为(public static
),即静态方法。
4. Random
java.util.Random
类用于产生随机数
常用方法
boolean nextBoolean()
:返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的 boolean 值。void nextBytes(byte[] bytes)
:生成随机字节并将其置于用户提供的 byte 数组中。double nextDouble()
:返回下一个伪随机数,它是取自此随机数生成器序列的、在 0.0 和 1.0 之间均匀分布的 double 值。float nextFloat()
:返回下一个伪随机数,它是取自此随机数生成器序列的、在 0.0 和 1.0 之间均匀分布的 float 值。double nextGaussian()
:返回下一个伪随机数,它是取自此随机数生成器序列的、呈高斯(“正态”)分布的 double 值,其平均值是 0.0,标准差是 1.0。int nextInt()
:返回下一个伪随机数,它是此随机数生成器的序列中均匀分布的 int 值。int nextInt(int n)
:返回一个伪随机数,它是取自此随机数生成器序列的、在 0(包括)和指定值(不包括)之间均匀分布的 int 值。long nextLong()
:返回下一个伪随机数,它是取自此随机数生成器序列的均匀分布的 long 值。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 Yomigaeri的博客!