swift – 在Xcode 6.3 Beta 3中尝试覆盖初始化程序时生成错误

前端之家收集整理的这篇文章主要介绍了swift – 在Xcode 6.3 Beta 3中尝试覆盖初始化程序时生成错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
以下代码显示Xcode 6.3 Beta 3中的构建错误.该代码适用于Xcode 6.2和Xcode 6.3 Beta 2.
class MyView: UIView {
  override init() {
    super.init()
    // Some init logic ...
  }

  override init(frame: CGRect) {
    super.init(frame: frame)
  }

  required init(coder aDecoder: NSCoder) {
    fatalError("init(coder:) has not been implemented")
  }
}

错误信息

initializer does not override a designated initializer from its superclass

解决方法

使用Beta 3 release notes中提到的init方法创建协议有可能的解决方法.我无法使init和init(frame:CGRect)初始化程序同时工作.

如何解决这些构建错误

一个子类的指定的初始化程序需要调用指定的超级类的初始化程序.一个方便的初始化器只能调用另一个方便的初始化器或该类的指定的初始化器.

init()是UIView的一个方便的初始化器,如果你在子类UIView你应该调用它的指定的初始化器是init(frame:frame)

override init() {
super.init(frame: frame)
// Some init logic ...
}

编辑:显然在Beta 3中,UIView没有方便的初始化器称为init,所以你需要删除override关键字,现在这是一个指定的初始化程序,所以你需要调用超类的指定的初始化程序

init() {
super.init(frame: frame)
// Some init logic ...
}

编辑:虽然这样做,但我认为写一个更好的方法是:

convenience init() {
self.init(frame:CGRectZero)
}

来源:Swift documentation

Rule 1 A designated initializer must call a designated initializer
from its immediate superclass.

Rule 2 A convenience initializer must call another initializer from
the same class.

Rule 3 A convenience initializer must ultimately call a designated initializer.

猜你在找的Swift相关文章