0

0

c++中如何判断两个浮点数是否足够接近_c++ epsilon精度比较方法【汇总】

冰火之心

冰火之心

发布时间:2026-01-23 15:08:40

|

722人浏览过

|

来源于php中文网

原创

<p>不能直接用 == 比较浮点数,因为其二进制近似表示导致 0.1+0.2≠0.3(实际为 0.30000000000000004),== 判断会错误返回 false;应使用 std::abs(a - b) < epsilon 判断是否接近。</p>

c++中如何判断两个浮点数是否足够接近_c++ epsilon精度比较方法【汇总】

为什么不能直接用 == 比较两个 floatdouble

浮点数在内存中是二进制近似表示,很多十进制小数(比如 0.1)根本无法精确存储。哪怕只是简单计算,如 0.1 + 0.2,结果也不是严格等于 0.3,而是类似 0.30000000000000004。直接用 == 判断会返回 false,即使数学上“应该相等”。这不是 bug,是 IEEE 754 的固有特性。

std::abs(a - b) 是最常用但有陷阱的方法

最直观的做法是判断差值的绝对值是否小于某个阈值 epsilon

bool is_close(double a, double b, double eps = 1e-9) {
    return std::abs(a - b) < eps;
}

但它只适用于数量级接近 0 的数。一旦 ab 很大(比如 1e10),1e-9 就远小于机器精度,导致永远返回 true;反过来,如果它们非常小(比如 1e-20),1e-9 又太大,可能漏判。所以固定 epsilon 不具备尺度不变性。

  • eps 应根据输入数量级动态调整,而不是硬编码
  • 0.0 附近比较,绝对误差法仍可用;但跨数量级时必须转向相对误差
  • 标准库没有提供通用的 is_close(C++23 才加入 std::is_close,目前多数项目还得自己写)

更鲁棒的写法:结合相对误差与绝对误差(推荐工业级用法)

NumPy 的 isclose 和 Python 标准库的思路已被广泛验证:同时检查相对误差和绝对误差,取其一满足即判定为“足够接近”:

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

Cliclic AI
Cliclic AI

Cliclic商品背景图编辑器是一款功能强大的AI工具,帮助用户快速生成具有吸引力的商品图背景。

下载
bool is_close(double a, double b, double rel_tol = 1e-9, double abs_tol = 1e-12) {
    if (std::abs(a - b) <= abs_tol) return true;
    return std::abs(a - b) <= rel_tol * std::max(std::abs(a), std::abs(b));
}

这种写法能自然覆盖极端情况:

  • ab 都接近 0(比如 1e-15),abs_tol 起主导作用
  • 当它们较大(比如 1e6),rel_tol 控制精度,避免被舍入误差淹没
  • std::max(std::abs(a), std::abs(b)) 确保分母不为零,且选择更稳妥的尺度基准

C++23 的 std::is_close 怎么用?注意它还没普及

C++23 引入了 <cmath> 中的 std::is_close,接口与上面一致:

#include <cmath>
std::is_close(a, b, 1e-9, 1e-12); // 返回 bool

但目前主流编译器(GCC 13、Clang 16、MSVC 19.35)仅部分支持,且需显式开启 -std=c++23 并确认标准库实现已跟进。生产环境建议暂不依赖,优先使用自定义版本。

真正容易被忽略的是:浮点比较从来不是“是否相等”,而是“在当前上下文下是否可视为等价”。这个“上下文”包括数据来源(传感器?仿真?用户输入?)、后续运算敏感度、以及你愿意容忍的误差范围 —— 这些都得由人定,没法交给一个通用函数全自动决定。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

595

2024.04.28

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

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

108

2025.10.23

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

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

334

2025.08.29

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

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

108

2025.10.23

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1954

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

658

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2401

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

47

2026.01.19

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

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

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