c++ - 模板化检查是否存在类成员函数?

标签 c++ templates template-meta-programming sfinae

是否可以编写一个模板,根据类中是否定义了某个成员函数来更改行为?

这是我想写的一个简单例子:

template<class T>
std::string optionalToString(T* obj)
{
    if (FUNCTION_EXISTS(T->toString))
        return obj->toString();
    else
        return "toString not defined";
}

因此,如果 class T 定义了 toString(),那么它将使用它;否则,它不会。我不知道该怎么做的神奇部分是“FUNCTION_EXISTS”部分。

最佳答案

是的,使用 SFINAE,您可以检查给定的类是否提供了特定的方法。这是工作代码:

#include <iostream>

struct Hello
{
    int helloworld() { return 0; }
};

struct Generic {};    

// SFINAE test
template <typename T>
class has_helloworld
{
    typedef char one;
    struct two { char x[2]; };

    template <typename C> static one test( decltype(&C::helloworld) ) ;
    template <typename C> static two test(...);    

public:
    enum { value = sizeof(test<T>(0)) == sizeof(char) };
};
    
int main(int argc, char *argv[])
{
    std::cout << has_helloworld<Hello>::value << std::endl;
    std::cout << has_helloworld<Generic>::value << std::endl;
    return 0;
}

我刚刚使用 Linux 和 gcc 4.1/4.3 对其进行了测试。我不知道它是否可以移植到运行不同编译器的其他平台。

关于c++ - 模板化检查是否存在类成员函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44437374/

相关文章:

C++ 私有(private)构造函数(带参数)不允许实例化

c++ - Ubuntu 10.04,将 MAP_HUGETLB 与 MAP_SHARED 一起使用时出错

c++ - 在没有宏的情况下在 C++98 中创建类型列表时遇到问题

c++ - 使用元编程进行消息队列管理

c++ - 有没有办法使用相同的索引遍历std::tuple和std::array?

c++ - 如何从指针容器中找到一个元素?

c++ - 将 char 数组转换为另一种类型是否违反严格的别名规则?

c++ - 模板 vector 的 vector

c++ - 对引用成员进行偏移(非 POD)

c++ - 如果可用,调用类型的标记构造函数,否则默认