Math类
对数字开方
Math.sqrt(16) -> 4
对数字取整数
向上取整:Math.ceil(double a) [n/x] = [(n+x-1)/x] 向下取整:Math.floor(double a) 四舍五入取整:Math.round(double a)
例:
Math.ceil(24.1)–> 25
Math.floor(24.8)–> 24
Math.round(24.1)–> 24
Math.round(24.8)–> 25
import java.text.DecimalFormat;
public class Main {
public static void main(String[] args) {
double number1 = 25.00000;
double number2 = 5432.10;
//"#.######"指定了保留六位有效数字,小数点后不足6位不补0
DecimalFormat decimalFormat = new DecimalFormat("#.######");
// 设置最小小数位数为0,不写也可以
decimalFormat.setMinimumFractionDigits(0);
String formattedNumber1 = decimalFormat.format(number1);
String formattedNumber2 = decimalFormat.format(number2);
System.out.println(formattedNumber1); // 输出:25
System.out.println(formattedNumber2); // 输出:5432.1
}
}
高精度计算(数大于long)
import java.math.BigDecimal;
public class HighPrecisionExample {
public static void main(String[] args) {
// 使用字符串构造BigDecimal以确保精度准确
BigDecimal num1 = new BigDecimal("123.456");
BigDecimal num2 = new BigDecimal("789.012");
// 加法
BigDecimal sum = num1.add(num2);
// 减法
BigDecimal difference = num1.subtract(num2);
// 乘法
BigDecimal product = num1.multiply(num2);
// 除法,指定精度和舍入模式
BigDecimal quotient = num1.divide(num2, 10, BigDecimal.ROUND_HALF_UP);
// ROUND_HALF_UP 四舍五入 ROUND_UP(向上取 ROUND_DOWN 向下取
}
}
Number & Math 类方法
下面的表中列出的是 Number & Math 类常用的一些方法:
序号 | 方法与描述 |
---|---|
1 | xxxValue() 将 Number 对象转换为xxx数据类型的值并返回。 |
2 | compareTo() 将number对象与参数比较。 |
3 | equals() 判断number对象是否与参数相等。 |
4 | valueOf() 返回一个 Number 对象指定的内置数据类型 |
5 | toString() 以字符串形式返回值。 |
6 | parseInt() 将字符串解析为int类型。 |
7 | abs() 返回参数的绝对值。 |
8 | ceil() 返回大于等于( >= )给定参数的的最小整数,类型为双精度浮点型。 |
9 | floor() 返回小于等于(<=)给定参数的最大整数 。 |
10 | rint() 返回与参数最接近的整数。返回类型为double。 |
11 | round() 它表示四舍五入,算法为 Math.floor(x+0.5),即将原来的数字加上 0.5 后再向下取整,所以,Math.round(11.5) 的结果为12,Math.round(-11.5) 的结果为-11。 |
12 | min() 返回两个参数中的最小值。 |
13 | max() 返回两个参数中的最大值。 |
14 | exp() 返回自然数底数e的参数次方。 |
15 | log() 返回参数的自然数底数的对数值。 |
16 | pow() 返回第一个参数的第二个参数次方。 |
17 | sqrt() 求参数的算术平方根。 |
18 | sin() 求指定double类型参数的正弦值。 |
19 | cos() 求指定double类型参数的余弦值。 |
20 | tan() 求指定double类型参数的正切值。 |
21 | asin() 求指定double类型参数的反正弦值。 |
22 | acos() 求指定double类型参数的反余弦值。 |
23 | atan() 求指定double类型参数的反正切值。 |
24 | atan2() 将笛卡尔坐标转换为极坐标,并返回极坐标的角度值。 |
25 | toDegrees() 将参数转化为角度。 |
26 | toRadians() 将角度转换为弧度。 |
27 | random() 返回一个随机数。 |