我使用gcc 4.9.0和clang 3.5.0测试了以下代码。该程序输出' true'正如所料。但是,如果我删除枚举前面的注释,则会变为“假”。这里发生了什么?如何确保has_mem布尔值设置为true。我的最终目标是在结构A中有一个成员函数,只有当类T具有某个成员函数时才通过enable_if启用它。
#include <iostream>
#include <boost/tti/has_member_function.hpp>
BOOST_TTI_HAS_MEMBER_FUNCTION(func)
template<class T>
struct A
{
//enum : bool { has_mem= has_member_function_func<T,void,boost::mpl::vector<const T &> >::value };
A()
{
std::cout << std::boolalpha
<< has_member_function_func<T,void,boost::mpl::vector<const T &> >::value
<< "\n";
}
};
struct B : public A<B>
{
void func( const B& ) {}
};
int main()
{
B b;
}
答案 0 :(得分:0)
我发现以下方法解决了我的问题。
#include <iostream>
struct empty_ {};
template<class derT>
struct A
{
A( derT * ptr ) : m_ptr( ptr ) {}
//
template<class T=empty_>
void func() { m_ptr->f(); }
private:
derT *m_ptr;
};
struct B : public A<B>
{
B() : A<B>( this ) {}
void f() { std::cout << "B::f\n"; }
};
struct C : public A<C>
{
C() : A<C>( this ) {}
void g() { std::cout << "C::g\n"; }
};
int main()
{
B b;
C c;
b.func();
c.g();
// Does not compile (as disired) since class C does not have a function f()
//c.func();
}
它有效,因为函数func是一个模板函数,因此SFINAE负责enable_if功能。