原文 仅在基类上提供
正确重载
,而派生类上包含不正确
重载时,编译器不会检查基类重载
.如果派生类
没有任何重载,则它可以工作.例如:
struct Foo
{
void foo(Bar b)
{
b.bar(this);
}
}
struct Foobar {}
struct Foobar2 {}
class Base
{
void bar(Foo f) {}
void bar(Foobar2 f) {}
}
class Bar : Base
{
void call()
{
Foo f;
f.foo(this);
}
// 注释掉,则正常工作.
void bar(Foobar f) {}
}
简化示例:
void main()
{
Derived d;
A a;
d.fun(a);
}
struct A {}
struct B {}
struct C {}
class Base
{
void fun(A a) {}
void fun(C c) {}
}
class Derived : Base
{
// 注释掉,则可调用.
void fun(B b) {}
}
因为Base.fun
和Derived.fun
位于不同的重载集
中,而派生类
重载集掩盖
了基类
重载集.用反射
检查重载集
:
struct A {}
struct B {}
struct C {}
class Base
{
void fun(A a) {}
void fun(C c) {}
}
class Derived1 : Base
{
// 注释掉,调用Base.fun(A)
void fun(B b) {}
}
// 打印: tuple(fun)
pragma(msg, __traits(getOverloads, Derived1, "fun"));
class Derived2 : Base {}
// 打印:tuple(fun, fun)
pragma(msg, __traits(getOverloads, Derived2, "fun"));