我有两节课,Shape和Square
class Shape {
var numberOfSides = 0
var name: String
init(name:String) {
self.name = name
}
func simpleDescription() -> String {
return "A shape with \(numberOfSides) sides."
}
}
class Square: Shape {
var sideLength: Double
init(sideLength:Double, name:String) {
super.init(name:name) // Error here
self.sideLength = sideLength
numberOfSides = 4
}
func area () -> Double {
return sideLength * sideLength
}
}
Run Code Online (Sandbox Code Playgroud)
通过上面的实现,我得到错误:
property 'self.sideLength' not initialized at super.init call
super.init(name:name)
Run Code Online (Sandbox Code Playgroud)
为什么我必须self.sideLength在打电话前设置super.init?
Swift中的lazy属性是否相当于在Objective C中使用延迟加载模式覆盖getter?
我正在使用Big Nerd Ranch的最新iOS书籍学习iOS开发.我选择在Swift中实现他们的应用程序.在他们的一个应用程序中,他们在Objective C中有以下代码:
- (UIView *)headerView
{
// If you have not loaded the header view yet...
if (!_headerView) {
// Load HeaderView.xib
[[NSBundle mainBundle] loadNibNamed:@"HeaderView" owner:self options:nil]
}
return _headerView;
}
Run Code Online (Sandbox Code Playgroud)
Apple的Swift指南"@IBOutlet":
当您在Swift中声明一个出口时,编译器会自动将该类型转换为弱隐式展开的可选项,并为其指定初始值nil.实际上,编译器替换了@IBOutlet var name:使用@IBOutlet弱var name输入:Type!=没有.
正如在swift中的Lazy loading Properties中所指出的那样,有几个不同的选项.在这篇文章中他们都没有明确提到使用@IBOutlet进行延迟初始化,所以我最好尽力实现他们的建议,并想知道什么是最佳实践.
尝试#1(失败):遵循类似的模式,如AppDelegate.swift中的示例.这带来了问题"'IBOutlet'属性要求属性是可变的"
@IBOutlet var headerView : UIView {
// If the HeaderView has not been loaded yet...
if !_headerView {
// Load HeaderView.xib
NSBundle.mainBundle().loadNibNamed("HeaderView", owner: self, options: nil)
}
return _headerView!
}
var _headerView : UIView? …Run Code Online (Sandbox Code Playgroud)