Java中Math.round()方法原理解读
来源:互联网 发布:大量收购淘宝店铺 编辑:程序博客网 时间:2024/04/30 20:53
Java中Math.round()方法是将浮点数“四舍五入”转换成整数的方法,但这里的“四舍五入”和数学中的四舍五入有点差别,接下来就来解析一下在Java里的原理。
1、首先直接上测试代码:
public static void main(String[] args) {
System.out.println(Math.round(12.4));
System.out.println(Math.round(12.5));
System.out.println(Math.round(12.9));
System.out.println(Math.round(-12.4));
System.out.println(Math.round(-12.5));
System.out.println(Math.round(-12.9));
}
运行结果:
12
13
13
-12
-12
-13
在没有弄清原理之前,凭我自己猜想,我一直认为数字按照向0靠拢的思想,但结果表明我的猜想是错误的。
2、源码解析
看Math.round()内的实现,但JDK1.8内代码有点多(不知道其他版本的是怎样的),但其真正的意思也就是如下:
public static int round(float a) {
return (int)floor(a + 0.5f);
}
public static long round(double a) {
return (long)floor(a + 0.5d);
}
看到有两个重载的方法,一个接收float类型返回int类型,另一个接收double类型返回long类型,这也很好理解,float和int都是占4个字节,double和long占8个字节,这样精度就没有丢失。但平时使用的时候还是要注意,因为实际应用中最常用double和int,所以可能需要转换。
1)从上面的两个方法可以看出,都是对数字加0.5后在再floor()方法
2)floo()方法的原理:取小于等于参数的最大整数浮点数(可以理解为向下取整数浮点数),如floor(12.5)=12.0,floor(12.9)=12.0,floor(-12.5)=-13.0,floor(-12.9)=-13.0。
3、结论
Math中的round方法,求的值就是取小于等于(参数+0.5)的最大整数。
- Java中Math.round()方法原理解读
- Java Math.round方法
- Java中Math类Math.floor()、Math.round()及Math.ceil()等方法的使用
- Java中Math.round()
- java中Math方法的ceil,floor,round方法
- 关于Java中if else,Math.round()方法的总结
- java 中 Math.round() Math.ceil() Math.floor()区别
- java中Math.round(),Math.ceil(),Math.floor()运算
- java中Math方法
- 关于java Math.round(Double a) 方法
- Java Math的floor、ceil、round方法
- Android中Math类Math.floor()、Math.round()及Math.ceil()等方法的使用
- JAVA中Math.round负数的“五舍六入”
- Math.Round 方法
- Math.round()方法
- Math.round()方法
- Math.round()方法
- Guava中Math的各个类中方法解读
- 根据字符串恢复IP问题
- ubuntu14.04 出现symbol lookup error
- 背包问题
- QSplitter在QTabWidget中使用
- 如何做出正确的选择
- Java中Math.round()方法原理解读
- js中函数对象的方法,原型方法apply、call、bind、toString、toLocaleString、valueOf
- to Gali
- myeclipse导入新工程后Ctrl+左键查看类源码失灵解决
- leetcode 140. Word Break II 动态规划DP + DFS深度优先搜索
- 洛谷 P1196 银河英雄传说
- 理解 JVM:JVM 内存模型
- STM32之ADC
- 【opencv学习之十一】opencv: HighGUI参考手册