Java之浮点数运算
浮点数运算和整数运算相比,只能进行加减乘除这些数值运算,不能做位运算和移位运算。
在计算机中,浮点数虽然表示的范围很大,但是浮点数有个非常重要的特点,就是浮点数常常无法精确表示
举例
浮点数0.1
在计算机中就无法精确表示,因为十进制的0.1
换算成二进制是一个无限循环小数,很显然,无论使用float
还是double
,都只能存储一个0.1
的近似值。但是,0.5
这个浮点数又可以精确地表示。因为浮点数常常无法精确表示,因此,浮点数运算会产生误差:
1 2 3 4 5 6 7 8 | public class Main { public static void main(String[] args) { double x= 1.0 / 10 ; double y= 1 - 9.0 / 10 ; System.out.println(x); System.out.println(y); } } |
运行结果
1 2 | 0.1 0.09999999999999998 |
由于浮点数存在运算误差,所以比较两个浮点数是否相等常常会出现错误的结果。正确的比较方法是判断两个浮点数之差的绝对值是否小于一个很小的数:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | public class Main { public static void main(String[] args) { double x= 1.0 / 10 ; double y= 1 - 9.0 / 10 ; System.out.println(x); System.out.println(y); double r=Math.abs(x-y); if (r< 0.00001 ) { System.out.println( "true" ); } else { System.out.println( "false" ); } } } |
浮点数在内存的表示方法和整数比更加复杂。Java的浮点数完全遵循IEEE-754标准,这也是绝大多数计算机平台都支持的浮点数标准表示方法。
类型提升
如果参与计算的两个数其中一个是整型,那么整型可以自动提升到浮点型
1 2 3 4 5 6 7 | public class Main { public static void main(String[] args) { int n= 5 ; double d= 1.2 + 24.0 /n; System.out.println(d); //6.0 } } |
需要特别注意,在一个复杂的四则运算中,两个整数的运算不会出现自动提升的情况。例如:
1 | double d = 1.2 + 24 / 5 ; // 5.2 |
计算结果为4.2,原因是编译器计算24/5这个子表达式时,按两个整数进行运算,结果为4,而不是按浮点运算4.8
溢出
整数运算在除数为0
时会报错,而浮点数运算在除数为0
时,不会报错,但会返回几个特殊值:
NaN
表示Not a NumberInfinity
表示无穷大-Infinity
表示负无穷大
例如
1 2 3 | double d1 = 0.0 / 0 ; // NaN double d2 = 1.0 / 0 ; // Infinity double d3 = - 1.0 / 0 ; // -Infinity |
这三种特殊值使用较少
强制转型
可以将浮点数强制转型为整数,在转型时,浮点数的小数部分会被丢弃。如果转型后超过了整型能表示的最大范围,将返回整型最大值
1 2 3 4 5 6 7 8 9 10 11 12 | public class Main { public static void main(String[] args) { int n1=( int ) 12.3 ; //12 System.out.println(n1); int n2=( int ) 12.7 ; //12 System.out.println(n2); int n3=( int ) - 12.7 ; //-12 System.out.println(n3); int n4=( int ) 9999999991.11 ; //2147483647 System.out.println(n4); } } |
小结
浮点数无法精确表示,并且浮点数的运算结果可能有误差。
比较两个浮点数通常比较他们的绝对值之差是否小于一个特定值。
整型和浮点型运算时,整型会自动提升为浮点型。
可以将浮点型强制转换为整型,但超出范围后将始终返回整型的最大值。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2017-10-25 Oracle下回滚rollback的使用
2017-10-25 Oracle下Delete语句
2017-10-25 Oracle下Update语句
2017-10-25 Oracle下Insert的介绍
2017-10-25 Oracle在linux下命令行无法使用退格键退格,无法使用上下键切换历史命令的解决办法
2017-10-25 Oracle表的维护(字段,重命名表名)
2017-10-25 Oracle数据库类型date