C++ - 比较两个浮点数大小

简介

两个浮点数不能直接使用  == 来确定相等,因为浮点数精度可能导致微小的误差

 

方法一:

使用std::abs()函数来比较两个浮点数的差值是否小于一个非常小的阈值

复制代码
float a = 1.5;
float b = 2.3;
float epsilon = 1e-9;
 
if (std::abs(a - b) < epsilon) {
    cout << "a is equal to b" << endl;
} else if (a < b) {
    cout << "a is less than b" << endl;
} else {
    cout << "a is greater than b" << endl;
}
复制代码

 

方法二:

使用std::numeric_limits<float>::epsilon()函数来比较两个浮点数的差值是否小于浮点数类型的最小可表示差值

复制代码
#include <limits>
 
float a = 1.5;
float b = 2.3;
 
if (std::abs(a - b) < std::numeric_limits<float>::epsilon()) {
    cout << "a is equal to b" << endl;
} else if (a < b) {
    cout << "a is less than b" << endl;
} else {
    cout << "a is greater than b" << endl;
}
复制代码

 

posted @   Citrusliu  阅读(625)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性
历史上的今天:
2020-05-25 ADB - 无需root禁用系统APP+关闭系统应用广告
点击右上角即可分享
微信分享提示