【问题标题】:Swift override instance variablesSwift 覆盖实例变量
【发布时间】:2014-11-29 02:23:33
【问题描述】:

我知道这个答案已经以其他形式发布在这里,但我想了解更多关于在 swift 中覆盖实例变量的信息。

假设我有这个代码

class BaseView:UIView{
 let someVariable:Int = 1
 // do some work with someVariable
}

class ExtendedView:BaseView{
 let someVariable:Int = 2
}

好的。根据我的阅读,该常量需要一个覆盖前缀。其他答案说我应该声明setter和getter?为什么?我真的不在乎这两个。我只需要替换值。我不能真正使用init 覆盖,因为我是从 UIView 继承的,这可能非常危险(我认为)。

欢迎提出任何建议。

【问题讨论】:

  • 正如所写的那样,那些看起来像独立且不相关的类变量,只是名称相同。

标签: ios class variables inheritance swift


【解决方案1】:

正如您所说,您不能简单地在子类中重新定义一个常量(毕竟它是一个常量)。您得到的错误是“不能用存储的属性覆盖”。似乎确实可以覆盖var,但是,当我将let someVariable 更改为var someVariable 时,当我在子类中访问它时,我得到“模糊使用'someVariable'”(注意-同样的事情发生在我是否使用override)。

最简单的解决方案是使用 getter。这确实是一个函数,因此您可以愉快地覆盖它,支持变量将为您管理,如果您不提供 setter ...它将是每个类的常量:

class BaseView: UIView {
    var someVariable: Int { get { return 1 } }
    // do some work with someVariable
}

class ExtendedView: BaseView {
    override var someVariable: Int { get { return 2 } }
}

let a = BaseView()
a.someVariable // 1
let b = ExtendedView()
b.someVariable // 2

正如评论员@user3633673 指出的那样,如果您只有有一个getter(而不是一个setter),您可以删除get,但为了清楚起见,我把它留了下来。没有它也是一样的......

class BaseView: UIView {
    var someVariable: Int { return 1 }
    // do some work with someVariable
}

class ExtendedView: BaseView {
    override var someVariable: Int { return 2 }
}

let a = BaseView()
a.someVariable // 1
let b = ExtendedView()
b.someVariable // 2

...当然,在 Swift 5 中,您可以删除 return:

class BaseView: UIView {
    var someVariable: Int { 1 }
}

class ExtendedView: BaseView {
    override var someVariable: Int { 2 }
}

【讨论】:

  • 对于一些读者应该注意的是,在简单的只读计算属性中“get”不是必需的。 var someVariable: Int { return 1 }var someVariable: Int { get { return 1 } } 的简写。
  • 其实你甚至可以做到var someVariable: Int { 1 }
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2017-01-08
  • 2011-11-11
  • 1970-01-01
  • 2014-11-04
  • 1970-01-01
  • 1970-01-01
  • 2013-06-24
相关资源
最近更新 更多