ich eine reale Situation haben, die in dem folgenden Beispiel zusammengefasst werden können:Mehrdeutige Mehrfachvererbung von Template-Klassen
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;
}
Warum ist dem Compiler nicht offensichtlich, dass B
ist ein TimeListener
und damit die einzig mögliche Überladungsauflösung ist Notifier<TimeListener>::add_listener(TimeListener&)
?
Sie Ihre Probleme lösen können mit 'mit Notifier :: add_listener; '(und der andere) in' struct A'. [Demo] (http://coliru.stacked-crooked.com/a/6e43848691a4cfcb) –
Jarod42