加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

在Swift中,为什么子类方法不能覆盖超类中协议扩展提供的方法

发布时间:2020-12-14 04:59:38 所属栏目:百科 来源:网络整理
导读:我知道这个问题的标题令人困惑,但下面的例子解释了奇怪的行为: protocol Protocol { func method() - String}extension Protocol { func method() - String { return "From Base" }}class SuperClass: Protocol {}class SubClass: SuperClass { func method
我知道这个问题的标题令人困惑,但下面的例子解释了奇怪的行为:

protocol Protocol {
    func method() -> String
}

extension Protocol {
    func method() -> String {
        return "From Base"
    }
}

class SuperClass: Protocol {
}

class SubClass: SuperClass {
    func method() -> String {
        return "From Class2"
    }
}

let c1: Protocol = SuperClass()
c1.method() // "From Base"
let c2: Protocol = SubClass()
c2.method() // "From Base"

为什么c1.method()和c2.method()返回相同的?为什么SubClass中的method()不起作用?

有趣的是,在没有声明c2的类型的情况下,这将起作用:

let c2  = SubClass()
c2.method() // "From Class2"

解决方法

问题是c1和c2属于Protocol类型,因为你已经用这种方式明确定义了它们的类型(记住:协议是完全成熟的类型).这意味着,当调用method()时,Swift调用Protocol.method.

如果你定义类似的东西:

let c3 = SuperClass()

… c3属于SuperClass类型.由于SuperClass没有更具体的method()声明,因此在调用c3.method()时仍然使用Protocol.method().

如果你定义类似的东西:

let c4 = SubClass()

… c4是SubClass类型.由于SubClass确实有一个更具体的method()声明,因此在调用c4.method()时会使用SubClass.method().

您也可以通过将它转发到SubClass来获取c2来调用SubClass.method():

(c2 as! SubClass).method() // returns "From Class2"

这是SwiftStub的演示.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读