0

0

c++怎么进行浮点数四舍五入_c++ round、ceil、floor函数区别【技巧】

冰火之心

冰火之心

发布时间:2026-01-07 14:35:02

|

713人浏览过

|

来源于php中文网

原创

std::round 是唯一实现四舍五入的函数,按 IEEE 754 向远离零舍入,需手动缩放指定小数位;ceil 和 floor 仅为方向性取整,与四舍五入无关。

c++怎么进行浮点数四舍五入_c++ round、ceil、floor函数区别【技巧】

round 是唯一做四舍五入的函数,但默认舍入到整数

std::rounddoublefloat 执行 IEEE 754 “舍入到最近整数,0.5 向远离零方向舍入”——也就是数学上常说的四舍五入。但它不支持直接指定小数位数,必须手动缩放:

  • 想保留 2 位小数:先乘 100,round,再除以 100.0
  • 注意用 100.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

ceil 和 floor 完全不是四舍五入,别混用

std::ceil 总是向上取整(≥ 当前值的最小整数),std::floor 总是向下取整(≤ 当前值的最大整数)。它们和“四舍五入”逻辑无关,只和方向有关:

  • ceil(2.1)3.0ceil(-2.1)-2.0
  • floor(2.9)2.0floor(-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 的陷阱:float 精度不足 + 头文件和命名空间

直接调用 round(1.234f) 可能调错重载版本,或触发隐式转换导致精度丢失:

  • 必须包含 ,否则行为未定义
  • float 值建议显式用 roundf(),避免 floatdoubleroundfloat 的中间误差
  • round(2.5) 在某些旧平台(如部分 C++11 实现)可能返回 2.0,因标准允许“向偶数舍入”作为实现选择;C++11 起已统一为“远离零”,但仍建议测试目标平台
  • 不要对 NaN 或无穷大调用,结果未定义
#include 
float f = 1.234f;
float r1 = roundf(f * 100.0f) / 100.0f; // 推荐:全程 float
float r2 = round(f * 100.0) / 100.0;     // 风险:先升 double 再降 float

需要保留 N 位小数时,别手写 pow,用整数幂更安全

pow(10, n) 做缩放看似方便,但 pow 返回 double,且对整数指数可能引入微小误差(如 pow(10, 2) 实际是 99.99999999999999),导致 round 错判:

墨狐AI
墨狐AI

5分钟生成万字小说,人人都是小说家!

下载

立即学习C++免费学习笔记(深入)”;

  • 对小数位数 ≤ 6 的情况,直接写 10.0100.01000.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 当“进一法四舍五入”用。记住——它只做整数级舍入,缩放必须自己控,且负数行为和直觉略有差异。

相关专题

更多
css中float用法
css中float用法

css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。

554

2024.04.28

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

97

2025.10.23

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

314

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

529

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

193

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

49

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

97

2025.10.23

C++ 高性能计算与并行编程
C++ 高性能计算与并行编程

本专题专注于 C++ 在高性能计算(HPC)与并行编程中的应用,涵盖多线程、并发数据处理、OpenMP、MPI、GPU加速等技术。通过实际案例,帮助开发者掌握 如何利用 C++ 进行大规模数据计算和并行处理,提高程序的执行效率,适应高性能计算与数据密集型应用场景。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.2万人学习

C 教程
C 教程

共75课时 | 3.9万人学习

C++教程
C++教程

共115课时 | 11.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号