Как работает следующий код?
typedef char (&yes)[1];
typedef char (&no)[2];
template <typename B, typename D>
struct Host
{
operator B*() const;
operator D*();
};
template <typename B, typename D>
struct is_base_of
{
template <typename T>
static yes check(D*, T);
static no check(B*, int);
static const bool value = sizeof(check(Host<B,D>(), int())) == sizeof(yes);
};
//Test sample
class Base {};
class Derived : private Base {};
//Expression is true.
int test[is_base_of<Base,Derived>::value && !is_base_of<Derived,Base>::value];
-
Обратите внимание, что
B
является частной базой. Как это работает? -
Обратите внимание, что
operator B*()
является константой. Почему это важно? -
Почему
template<typename T> static yes check(D*, T);
лучше, чемstatic yes check(B*, int);
?
Примечание. Это сокращенная версия (макросы удаляются) из boost::is_base_of
. И это работает в широком диапазоне компиляторов.