在Swift中,我们可以设置一个存储属性来使用闭包:
class Test {
var prop: String = {
return "test"
}()
}
VS
或使懒惰的存储属性使用闭包:
class Test {
lazy var prop: String = {
return "test"
}()
}
在这两种情况下,用于获取属性值的代码只运行一次。看起来它们是等价的。
在使用闭包时,何时应该使用延迟存储属性与计算属性?
答案 0 :(得分:18)
import Foundation
struct S {
var date1: NSDate = {
return NSDate()
}()
lazy var date2: NSDate = {
return NSDate()
}()
}
var s = S()
sleep(5)
print( s.date2, s.date1)
/* prints
2015-11-24 19:14:27 +0000 2015-11-24 19:14:22 +0000
*/
两者都是存储属性,检查它们的实时评估时间。当第一次需要值时,“按需”评估惰性属性