我有一个真实的情况,可以在下面的例子来概括:暧昧多重继承
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&)
?
您可以用'使用通知解决您的问题:: add_listener;'(另一个)在'struct A'中。 [Demo](http://coliru.stacked-crooked.com/a/6e43848691a4cfcb) –
Jarod42