如何解决在 C++ 中使用 cfenv 作为错误控制,使用 pow 作为 sqrt 的问题
我已经开始使用 cfenv 来检查变量的上溢和下溢,而且我已经看到您还可以检查其他内容,例如除以零和“无效”。
它通过无效运算给出的例子是-1的平方根,它有效:
#include <cfenv>
#include <cmath>
#include <iostream>
int main() {
std::feclearexcept(FE_INVALID);
double invalid_var = 0;
std::cout << "Invalid flag before: " << (bool)std::fetestexcept(FE_INVALID) << std::endl;
invalid_var = sqrt(-1);
std::cout << "Invalid flag after: " << (bool)std::fetestexcept(FE_INVALID) << std::endl;
return 0;
}
之前的无效标志:0
之后的无效标志:1
问题是在我的代码中我不使用 sqrt 作为平方根,我使用数学等价的 x^(1/2)。使用 pow 而不是 sqrt 它给出了结果 1,并且没有标志:
#include <cfenv>
#include <cmath>
#include <iostream>
int main() {
std::feclearexcept(FE_INVALID);
double invalid_var = 0;
std::cout << "Invalid flag before: " << (bool)std::fetestexcept(FE_INVALID) << std::endl;
invalid_var = pow(-1,1/2);
std::cout << "Invalid flag after: " << (bool)std::fetestexcept(FE_INVALID) << std::endl;
return 0;
}
之前的无效标志:0
之后的无效标志:0
有什么我可以做的吗?我是 C++ 新手,我不知道您使用的数学函数和异常类型,也许我给它的方法有误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。