У меня есть реальная ситуация, которую можно резюмировать в следующем примере:Неоднозначность множественного наследования классов шаблонов
template< typename ListenerType >
struct Notifier
{
void add_listener(ListenerType&){}
};
struct TimeListener{ };
struct SpaceListener{ };
struct A : public Notifier<TimeListener>
, public Notifier<SpaceListener>
{
};
struct B : TimeListener{ };
int main()
{
A a;
B b;
a.add_listener(b); // why is ambiguous?
return 0;
}
Почему не очевидно, что компилятор B
является TimeListener
, и поэтому единственно возможным разрешение перегрузки Notifier<TimeListener>::add_listener(TimeListener&)
?
Вы можете решить ваши проблемы с 'использованием Notifier :: add_listener; '(и другой) в' struct A'. [Demo] (http://coliru.stacked-crooked.com/a/6e43848691a4cfcb) –
Jarod42