提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
-
-
- 一、核心行为:截断小数部分(向零取整)
-
- [1. 正数场景](#1. 正数场景)
- [2. 负数场景](#2. 负数场景)
- 二、如果需要四舍五入,该怎么做?
-
- [1. Java](#1. Java)
- [2. C/C++](#2. C/C++)
- 三、补充:其他取整方式
- 总结
-
在主流编程语言(如Java、C/C++、C#等)中,将double(或float)强制类型转换为int时,并不是四舍五入,而是直接截断(舍弃)小数部分,遵循**「向零取整」**的规则(即结果向数轴上0的方向取整)。
一、核心行为:截断小数部分(向零取整)
无论小数部分是多少(0.1还是0.9),强制转换时只会保留整数部分,直接丢弃小数位。
1. 正数场景
java
// Java示例
double d1 = 3.14;
int i1 = (int) d1; // 结果:3(小数部分0.14被截断)
double d2 = 3.9999;
int i2 = (int) d2; // 结果:3(小数部分0.9999被截断)
double d3 = 5.0;
int i3 = (int) d3; // 结果:5(无小数部分,直接保留)
2. 负数场景
负数的强制转换同样是截断小数部分,向0的方向取整(而非向负无穷取整):
java
double d4 = -3.14;
int i4 = (int) d4; // 结果:-3(小数部分0.14被截断)
double d5 = -3.9999;
int i5 = (int) d5; // 结果:-3(小数部分0.9999被截断)
二、如果需要四舍五入,该怎么做?
强制转换的截断行为无法实现四舍五入,需使用语言提供的专用方法:
1. Java
使用Math.round()方法(四舍五入到最近的整数,中间值向正无穷取整):
java
double d6 = 3.5;
long l6 = Math.round(d6); // 结果:4(四舍五入)
int i6 = (int) Math.round(d6); // 转int:4
double d7 = -3.5;
long l7 = Math.round(d7); // 结果:-3(中间值向正无穷取整)
int i7 = (int) Math.round(d7); // 转int:-3
2. C/C++
使用<cmath>头文件中的round()函数(需注意返回值是浮点型,需转int):
cpp
#include <cmath>
#include <iostream>
using namespace std;
int main() {
double d = 3.9;
int i = (int)round(d); // 结果:4(四舍五入)
cout << i << endl;
double d2 = -3.9;
int i2 = (int)round(d2); // 结果:-4(四舍五入)
cout << i2 << endl;
return 0;
}
注意:不要用
(int)(num + 0.5)的方式(仅对正数有效,负数会出错,比如-3.5 + 0.5 = -3.0,转int是-3,而非四舍五入的-4)。
三、补充:其他取整方式
| 取整规则 | Java方法 | C/C++函数 | 示例(3.9/-3.1) |
|---|---|---|---|
| 向零取整(截断) | 强制类型转换 | 强制类型转换 | 3 / -3 |
| 四舍五入 | Math.round() | round() | 4 / -3 |
| 向负无穷取整 | Math.floor() | floor() | 3 / -4 |
| 向正无穷取整 | Math.ceil() | ceil() | 4 / -3 |
总结
- 强制转换
double→int:直接截断小数部分,向零取整,与四舍五入无关; - 四舍五入需求 :必须使用语言的专用方法(如
Math.round()/round())。