d有相同名类方法重载不适用于基类

原文
仅在基类上提供正确重载,而派生类上包含不正确重载时,编译器不会检查基类重载.如果派生类没有任何重载,则它可以工作.例如:

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.funDerived.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"));
posted @   zjh6  阅读(29)  评论(0编辑  收藏  举报  
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示