我们先通过以下实例来看看 Java Math floor、ceil、rint 及 round 各个方法的输出结果:
Test.java
import java.util.Scanner;
public class Test {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.println("输入一个浮点数:");
while(sc.hasNext()){
double num = sc.nextDouble();
System.out.println("Math.floor(" + num + ") = " + Math.floor(num));
System.out.println("Math.ceil(" + num + ") = " + Math.ceil(num));
System.out.println("Math.rint(" + num + ") = " + Math.rint(num));
System.out.println("Math.round(" + num + ") = " + Math.round(num));
}
}
}
执行以上程序测试输出:
$ javac Test.java $ java Test 输入一个浮点数: 2.2 Math.floor(2.2) = 2.0 Math.ceil(2.2) = 3.0 Math.rint(2.2) = 2.0 Math.round(2.2) = 2 -2.2 Math.floor(-2.2) = -3.0 Math.ceil(-2.2) = -2.0 Math.rint(-2.2) = -2.0 Math.round(-2.2) = -2 -2.5 Math.floor(-2.5) = -3.0 Math.ceil(-2.5) = -2.0 Math.rint(-2.5) = -2.0 Math.round(-2.5) = -2 2.5 Math.floor(2.5) = 2.0 Math.ceil(2.5) = 3.0 Math.rint(2.5) = 2.0 Math.round(2.5) = 3 2.7 Math.floor(2.7) = 2.0 Math.ceil(2.7) = 3.0 Math.rint(2.7) = 3.0 Math.round(2.7) = 3 -2.7 Math.floor(-2.7) = -3.0 Math.ceil(-2.7) = -2.0 Math.rint(-2.7) = -3.0 Math.round(-2.7) = -3
解析输出
1、Math.floor() 向下取整,即小于这个数的最大的那个整数。
Math.floor(2.2) = 2.0; Math.floor(-2.2) = -3.0; Math.floor(2.5) = 2.0; Math.floor(-2.5) = -3.0; Math.floor(2.7) = 2.0; Math.floor(-2.7) = -3.0;
2、Math.ceil() 向上取整,即大于这个数的最小的那个整数。
Math.ceil(2.2) = 3.0; Math.ceil(-2.2) = -2.0; Math.ceil(2.5) = 3.0; Math.ceil(-2.5) = -2.0; Math.ceil(2.7) = 3.0; Math.ceil(-2.7) = -2.0;
3、Math.rint() 返回最接近该值的那个整数。
注意: 如果存在两个这样的整数,则返回其中的偶数。
4、Math.round() 四舍五入,但当参数为负数时不太好理解,直接上源码应该比较好理解,注意返回的是整型。
Math.round(x) = Math.floor(x + 0.5)
把以上代码带入以下实例测试:
Math.round(2.2) = 2; Math.round(-2.2) = -2; Math.round(2.5) = 3; Math.round(-2.5) = -2; Math.round(2.7) = 3; Math.round(-2.7) = -3
参考地址:https://blog.csdn.net/u012050154/article/details/52448260