在 clang 中,我们可以忽略警告,如 here 所述.
在我的示例中,如果代码直接包含在 pragma 中(请参阅 (1)
),则此方法工作正常。然而,这在 (2)
中不起作用,因为有问题的代码在函数 (3)
中。仅当我用编译指示(已注释掉)将函数括起来时,才会忽略该警告。如果该函数位于 header 内,我还可以使用编译指示将 #include
括起来。
我通常希望针对此功能发出警告,但我不想在使用它的整个文件中禁用它们。那么有没有办法在每个用例上禁用警告?
#include <iostream>
// #pragma clang diagnostic push
// #pragma clang diagnostic ignored "-Wfloat-equal"
template <class T>
bool compare (const T lhs, const T rhs)
{
return lhs == rhs; // (3)
}
// #pragma clang diagnostic pop
int main ()
{
const float a = 1.1f, b = 1.1f;
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wfloat-equal"
const bool eq1 = a == b; // (1)
#pragma clang diagnostic pop
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wfloat-equal"
const bool eq2 = compare (a, b); // (2)
#pragma clang diagnostic pop
std::cout << eq1 << " " << eq2 << std::endl;
return 0;
}
编译-Weverything
最佳答案
使用 ==
进行比较时会发出警告, 不是为了打电话。如果你有两个函数都调用 compare<float>
,并且您会以某种方式设法抑制第一次调用的警告,在第二次调用中不会有任何警告:compare<float>
已经被实例化,并且只有在实例化期间才会检测到要警告的任何内容。
您应该可以找到可以附加到对 compare<float>
的调用的警告.默认参数在调用站点有效地得到评估,并且快速测试表明它适用于此:
template <typename T>
bool compare(T a, T b, bool = decltype(a == b)()) {
#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wfloat-equal"
return a == b;
#pragma clang diagnostic pop
}
// Gets a warning
void f() { compare(1.0f, 1.0f); }
// Suppress the warning here
void g() { compare(1.0f, 2.0f, false); }
// Gets another warning
void h() { compare(1.0f, 3.0f); }
关于c++ - 跨函数禁用 clang 警告,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28664574/