Я видел этот question, который позволяет проверять существование функции-члена, но я пытаюсь узнать, имеет ли класс тип члена.
В приведенном ниже примере оба параметра оцениваются как "false", но я хотел бы найти способ, чтобы has_bar<foo1>::value
оценивался как false, а has_bar<foo2>::value
оценивался как true.
Возможно ли это?
#include <iostream>
struct foo1;
struct foo2 { typedef int bar; };
template <typename T>
class has_bar
{
typedef char yes;
typedef long no;
template <typename C> static yes check( decltype(&C::bar) ) ;
template <typename C> static no check(...);
public:
enum { value = sizeof(check<T>(0)) == sizeof(yes) };
};
int main()
{
std::cout << has_bar<foo1>::value << std::endl;
std::cout << has_bar<foo2>::value << std::endl;
return 0;
}
Изменить: реализовать специализацию в ответ на ответы ниже:
... если вы используете C:: bar в целевом шаблоне, шаблон будет автоматически отбрасывается для типов, которые не имеют этого вложенного типа.
Я попытался сделать это, но я явно что-то пропустил
#include <iostream>
struct foo1;
struct foo2 { typedef int bar; };
template <typename T, typename U = void>
struct target
{
target()
{
std::cout << "default target" << std::endl;
}
};
template<typename T>
struct target<T, typename T::bar>
{
target()
{
std::cout << "specialized target" << std::endl;
}
};
int main()
{
target<foo1>();
target<foo2>();
return 0;
}