Ho una situazione reale che si può riassumere nel seguente esempio:ambiguo ereditarietà multipla di classi template
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;
}
Perché non è evidente per il compilatore che B
è un TimeListener
, e quindi l'unica possibile la risoluzione di sovraccarico è Notifier<TimeListener>::add_listener(TimeListener&)
?
Si può risolvere i vostri problemi con 'utilizzando Notifier :: add_listener; '(e l'altro) in' struct A'. [Demo] (http://coliru.stacked-crooked.com/a/6e43848691a4cfcb) –
Jarod42