std::round 是唯一实现四舍五入的函数,按 IEEE 754 向远离零舍入,需手动缩放指定小数位;ceil 和 floor 仅为方向性取整,与四舍五入无关。
std::round 对 double 或 float 执行 IEEE 754 “舍入到最近整数,0.5 向远离零方向舍入”——也就是数学上常说的四舍五入。但它不支持直接指定小数位数,必须手动缩放:
round,再除以 100.0100.0(浮点字面量),避免整数除法截断round(-2.5) 得 -3.0(不是 -2)double x = 3.14159; double y = round(x * 100.0) / 100.0; // → 3.14 double z = round(-2.5); // → -3.0
std::ceil 总是向上取整(≥ 当前值的最小整数),std::floor 总是向下取整(≤ 当前值的最大整数)。它们和“四舍五入”逻辑无关,只和方向有关:
ceil(2.1) → 3.0,ceil(-2.1) → -2.0
floor(2.9) → 2.0,floor(-2.9) → -3.0
double a = 2.1, b = -2.1; std::cout << ceil(a) << " " << ceil(b) << "\n"; // 3 -2 std::cout << floor(a) << " " << floor(b) << "\n"; // 2 -3
直接调用 round(1.234f) 可能调错重载版本,或触发隐式转换导致精度丢失:
,否则行为未定义float 值建议显式用 roundf(),避免 float→double→round→float 的中间误差round(2.5) 在某些旧平台(如部分 C++11 实现)可能返回 2.0,因标准允许“向偶数舍入”作为实现选择;C++11 起已统一为“远离零”,但仍建议测试目标平台NaN 或无穷大调用,结果未定义#includefloat f = 1.234f; float r1 = roundf(f * 100.0f) / 100.0f; // 推荐:全程 float float r2 = round(f * 100.0) / 100.0; // 风险:先升 double 再降 float
用 pow(10, n) 做缩放看似方便,但 pow 返回 double,且对整数指数可能引入微小误差(如 pow(10, 2) 实际是 99.99999999999999),导致 round 错判:
10.0、100.0、1000.0 更可靠std::pow(10.0, n) + 小范围修正(如加 1e-9),但多数业务场景位数固定int(round(x * 100)))可规避浮
点缩放误差,但要注意溢出// 安全(固定 3 位) double x = 12.345678; double rounded = round(x * 1000.0) / 1000.0; // → 12.346// 不推荐(pow 引入误差风险) double scale = pow(10.0, 3); // 可能不是精确 1000.0
实际项目里最常踩的坑是:以为 round 能直接指定小数位,或者把 ceil 当“进一法四舍五入”用。记住——它只做整数级舍入,缩放必须自己控,且负数行为和直觉略有差异。