コード内:
template<class T>
struct is_builtin
{
enum {value = 0};
};
template<>
struct is_builtin<char>
{
enum {value = 1};
};
template<>
struct is_builtin<int>
{
enum {value = 1};
};
template<>
struct is_builtin<double>
{
enum {value = 1};
};
template<class T>
struct My
{
typename enable_if<is_builtin<T>::value,void>::type f(T arg)
{
std::cout << "Built-in as a param.\n";
}
typename enable_if<!is_builtin<T>::value,void>::type f(T arg)
{
std::cout << "Non - built-in as a param.\n";
}
};
struct A
{
};
int main()
{
A a;
My<int> m;
My<A> ma;
m.f(1);
ma.f(a);
return 0;
}
エラーが発生しました:
error C2039: 'type' : is not a member of 'std::tr1::enable_if<_Test,_Type>'
明らかに、私は使用方法を理解していませんenable_if
。私が考えていたのは、コンパイル時に一連のメンバー関数から1つまたは2番目の1つのメンバー関数を有効にできるが、機能しないということでした。誰かがそれを正しく行う方法を私に説明してもらえますか?
編集
私が本当に理解できないのは、なぜtypedef
それらのdefの1つに存在しないのかということです。コンパイラはそれを見つけることができず、コンパイルしません。