一. 关于浮点运算,需要说明的几点:
1. 在java中,进行浮点运算并不会处理例外情况,所以,即使除数为0,也不会有例外被抛出;
2. 当运算结果是溢出(Infinity)时,结果为Infinity;下溢时,则结果为0;若结果是数学上是未定义的,则结果为NaN(not a number);
3. 所有和NaN有关的运算其结果总是NaN;
4. 由于NaN是无序的,所以,和NaN进行数值比较时,其结果总是false.
二. 例子:
public class floattest {
public static void main(String args[]) {
double num = 1.0E200;
System.out.println(num*num);
double num2 = 1.0E-323;
System.out.println(num2/10.0);
System.out.println(1.0/0.0);
System.out.println(-1.0/0.0);
double numNan = 0.0/0.0;
System.out.println(numNan);
System.out.println(numNan > 0);
}
}
三. 测试结果:
/*
Infinity
0.0
Infinity
-Infinity
NaN
false
*/
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步