c++ - SFINAE 显式工作但不隐式工作

标签 c++ c++11 sfinae

我正在使用一个库的多个不同版本,这些库定义了不同的枚举集,并且我试图根据是否存在不同的值在编译时进行切换。我正在使用 decltype()... 技巧:

enum E {
    FOO = 0,
    BAR
};

template <typename U>
inline void add_FOO(std::vector<U>& v, decltype(U::FOO)* ) {
    std::cout << "YES\n";
}

template <typename U>
inline void add_FOO(std::vector<U>& v, ... ) {
    std::cout << "NO\n";
}

但是当我尝试使用它时:

std::vector<E> v;
add_FOO(v, nullptr);      // prints NO
add_FOO<E>(v, nullptr);   // prints YES

为什么不同? U 应该被推断为 E,那么为什么我需要明确指定它呢?我正在 gcc 4.7.2 上编译。

最佳答案

在我看来像是 GCC 错误。有很多解决方法。例如:

template <typename U>
inline auto add_FOO(std::vector<U>& v, int) -> decltype(U::FOO, void()) {
    std::cout << "YES\n";
}

template <typename U>
inline void add_FOO(std::vector<U>& v, ... ) {
    std::cout << "NO\n";
}

add_FOO(v, 0);

template <typename U, decltype(U::FOO)* = nullptr>
inline void add_FOO(std::vector<U>& v, int) {
    std::cout << "YES\n";
}

template <typename U>
inline void add_FOO(std::vector<U>& v, ... ) {
    std::cout << "NO\n";
}

add_FOO(v, 0);

关于c++ - SFINAE 显式工作但不隐式工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29521615/

相关文章:

c++ - 我可以在所有 MSVC >= 2013 上安全地使用哪些 SFINAE 技巧?

c++ - 在尝试使用 SFINAE 禁用功能时,我是否创建了未定义的行为?

c++ - 使用继承时的复制构造函数

c++ - apache thrift 是否支持函数变量作为参数?

c++ - 无法随内容一起初始化 vector 的大小

c++ - 是否可以在 O(1) 时间内为 C++ vector 分配新值?

c++ - 为什么 vector<std::function> 的元素可以绑定(bind)到 C++ 中的不同函数签名?

c++ - 将模板参数限制为仅具有不同构造函数签名的一组类

c++ - 如何判断何时在 QButtonGroup 中单击 QPushButton

c++ - 有没有办法检查缓冲区是否为 Brotli 压缩格式?