不能直接用 == 比较两个 float 或 double,因为浮点数是二进制近似表示,0.1+0.2≠0.3(实际为0.30000000000000004),应使用 std::abs(a - b)
为什么不能直接用 == 比较两个
float或double因为浮点数在内存中是二进制近似表示,很多十进制小数(比如
0.1)根本无法精确存储。哪怕只是简单计算,如0.1 + 0.2,结果也大概率不等于0.3——它可能是0.30000000000000004。直接用==判断会返回false,即使数学上“应该相等”。用
std::abs(a - b) 是最常用方法核心思路:不看“是否完全相等”,而是看“差值是否足够小”。
epsilon是你接受的误差上限。
epsilon不是固定值:对大数(如1e10)和小数(如1e-10),同样的绝对误差意义完全不同;一般先从1e-9(float)或1e-15(double)试起- 必须包含
(C++17 起std::abs在此头文件)- 示例:
#includebool nearly_equal(double a, double b, double eps = 1e-9) { return std::abs(a - b) < eps; } - 注意:这个方法对接近零的数效果尚可,但对极大或极小数值容易失效——比如比较
1e20和1e20 + 1,差值是1,远大于1e-9,但这两个数在double精度下本就无法区分相对误差判断更鲁棒:
std::abs(a - b)适用于大多数非零场景,能随数值大小自动缩放容差。
- 要避免除零,所以通常写成:
std::abs(a - b)- C++ 标准库提供
std::numeric_limits,但它表示的是::epsilon() 1.0附近的最小可分辨差值(即1.0 + epsilon != 1.0),**不是通用比较阈值**;直接拿它当epsilon用往往太小(double的epsilon是 ~2.2e-16)- 实用建议:对
double,相对容差常设为1e-12~1e-14;对float,用1e-5~1e-6- 更稳妥的写法(兼顾零值):
bool nearly_equal(double a, double b, double rel_eps = 1e-12, double abs_eps = 1e-15) { double diff = std::abs(a - b); double scale = std::max({std::abs(a), std::abs(b), 1.0}); return diff <= std::max(abs_eps, rel_eps * scale); }别忽略 NaN 和无穷大
任何与
NaN的比较(包括==、、std::abs)都返回false,且std::abs(NaN)还是NaN。如果你的输入可能含NaN,必须显式检查:立即学习“C++免费学习笔记(深入)”;
- 用
std::isnan(a)或std::isnan(b)提前判断;若任一为NaN,通常应直接返回false(除非业务允许NaN == NaN)std::isinf(a)可检测无穷大;两个同号无穷大可认为“相等”,但需按需处理- 标准库没有提供开箱即用的“安全浮点比较”,自己封装时务必覆盖这些边界情况
实际项目里,最易被忽略的是:把
std::numeric_limits当作万能阈值直接套用,或者忘记 NaN 处理导致断言崩溃或逻辑跳变。::epsilon()
0
0
相关文章
C++ 怎么输出中文乱码解决 C++ setlocale与编码设置指南【环境】
c++中priority_queue怎么用_c++优先队列使用指南【教程】
C++ reinterpret_cast用法 C++底层二进制强制转换详解【危险】
C++ map count用法 C++ 判断键是否存在的推荐方式【查询】
C++ 怎么判断素数 C++ sqrt优化质数判定代码【数学】
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
css中float用法
css中float属性允许元素脱离文档流并沿其父元素边缘排列,用于创建并排列、对齐文本图像、浮动菜单边栏和重叠元素。想了解更多float的相关内容,可以阅读本专题下面的文章。
580
2024.04.28
C++ 设计模式与软件架构
本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。
9
2026.01.30
热门下载
相关下载
最新文章








