我知道这个答案已经以其他形式发布在这里,但我想了解更多关于在 swift 中覆盖实例变量的信息。
假设我有这段代码
class BaseView:UIView{
let someVariable:Int = 1
// do some work with someVariable
}
class ExtendedView:BaseView{
let someVariable:Int = 2
}
好的。根据我的阅读,常量需要一个覆盖前缀。其他答案说我应该声明setter和getter?为什么?我真的不在乎那两个。我只需要替换值。我不能真正使用 init
覆盖,因为我是从 UIView 继承的,这可能非常危险(我认为)。
欢迎提出任何建议。
最佳答案
正如您所说,您不能简单地在子类中重新定义一个常量(毕竟它是一个常量)。您收到的错误是“无法使用存储的属性覆盖”。似乎确实可以覆盖 var
,但是,当我将 let someVariable
更改为 var someVariable
时,我得到“不明确使用 ' someVariable'"当我在子类中访问它时(注意 - 无论我是否使用 override
都会发生同样的事情)。
最简单的解决方案是使用 setter/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 }
}
关于ios - Swift 覆盖实例变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26188903/