C++ 双重比较的奇怪行为
C++ Strange behavior with double comparaison
我正在为我的应用程序开发一个单元测试,但我面临着一个我不明白的奇怪问题。
代码为:
double res = BytesTool::convertSize(1, BytesTool::Byte, BytesTool::KiloByte);
double tmp = pow((double)1000, -1);
QVERIFY(res == tmp);
我正在从Linux机器(主机64位)编译Linux 64位与gcc(主机64位),并使用Linux的mingw32编译器交叉编译Windows 32bits。
该程序在调试和发布模式下运行良好(断言成功),Linux 编译。对于 Windows 版本,它在调试版本中工作正常,但在发布版本中则不然;断言失败。
奇怪的是,如果我插入跟踪,测试在 Windows 中工作:
double res = BytesTool::convertSize(1, BytesTool::Byte, BytesTool::KiloByte);
printf("test");
double tmp = pow((double)1000, -1);
QVERIFY(res == tmp); // Is TRUE when printf("test") is present, FALSE otherwise
我迷路了,我真的不明白发生了什么。为什么printf
让它工作?
感谢您的帮助。
printf 将导致它工作,因为浮点数将从内部 FPU 80 位表示形式(假设 x86"旧式"数学)转换为保存在双精度中的 64 位。
这样做的原因是,当您调用另一个函数时,寄存器值必须移动到堆栈中(同样,假设 x86 旧式 FPU 调用约定),这将导致它四舍五入到 64 位精度。
您的其他编译很可能有效,因为它们使用的是具有本机 64 位浮点类型的 SSE2+ 数学。
==
测试浮点数是否相同,这几乎从来都不是浮点数的正确做法。
在这种情况下,不是因为内部 CPU 表示形式与存储在双精度中的表示形式不同。
比较浮点数时,请始终检查它们是否彼此足够接近而不是相等。
#include <math.h>
QVERIFY( fabs(res-tmp) < DBL_EPSILON )
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么比较运算符如此快速
- 我可以使用 g++ 进行三种比较 (<=>) 吗?
- 比较字符数组
- 将模板化的类型与C++中的某些类/类型进行比较
- C++自定义比较函数
- 如何比较自定义类的std::变体
- 多个If语句与使用逻辑运算符计算条件的单个语句的比较
- std::设置自定义比较器
- 布尔比较运算符是如何在C++中工作的
- C++将目录中的所有文件与::filesystem进行比较
- shell排序中的交换和比较
- 如何在C++中比较两个char数组
- catch框架有没有办法比较流或文件
- 从文件中读取多个字节,并将它们存储在C++中进行比较
- 智能指针作为无序映射键,并通过引用进行比较
- 比较if语句中的数组值和int值
- 对于循环变体比较
- 使用自定义比较函数使用std::sort()对矢量字符串进行排序时出现问题
- 比较两个大小不等的映射c++