直接赋值截断小数,round()实现四舍五入,floor/ceil向下向上取整,加0.5法仅适用正数。推荐使用std::round()。

在C++中,将double类型转换为int时,直接赋值会截断小数部分(即向零取整),但实际开发中我们常常需要四舍五入或其他取整方式。以下是几种常用方法。
1. 直接赋值:截断取整(向零取整)
将double直接赋给int变量时,编译器会自动截断小数部分,只保留整数部分。
double d = 3.7; int i = d; // i = 3 double d2 = -3.7; int i2 = d2; // i2 = -3(向零取整)
这种方式不是四舍五入,而是简单地去掉小数部分。
2. 使用round()函数:四舍五入
C++标准库提供了round()函数,可实现数学上的四舍五入。
立即学习“C++免费学习笔记(深入)”;
#includedouble d = 3.7; int i = static_cast (round(d)); // i = 4 double d2 = -3.7; int i2 = static_cast (round(d2)); // i2 = -4
注意:返回值是double,需显式转为int。
3. 其他取整函数(向下、向上取整)
还提供以下函数:
-
floor(x):向下取整(向负无穷) -
ceil(x):向上取整(向正无穷)
#includedouble d = 3.2; int a = static_cast (floor(d)); // 3 int b = static_cast (ceil(d)); // 4
4. 手动四舍五入技巧(适用于正数)
对正数可通过加0.5再截断实现四舍五入:
double d = 3.7; int i = static_cast(d + 0.5); // i = 4
注意:此法对负数不适用。例如-3.7 + 0.5 = -3.2,转为int得-3,不符合四舍五入规则。若需支持负数,应使用round()。
基本上就这些常见方法。推荐优先使用std::round(),简洁且符合标准。手动加0.5适合简单场景,但要注意符号问题。









