我是Swift的新手。 计算属性和设置为闭包的属性之间有什么区别? 我知道每次都会重新计算一个计算属性。 封盖是否有所不同? 即
关闭:
var pushBehavior: UIPushBehavior = {
let lazilyCreatedPush = UIPushBehavior()
lazilyCreatedPush.setAngle(50, magnitude: 50)
return lazilyCreatedPush
}()
计算:
var pushBehavior: UIPushBehavior {
get{
let lazilyCreatedPush = UIPushBehavior()
lazilyCreatedPush.setAngle(50, magnitude: 50)
return lazilyCreatedPush
}
}
第一个是通过闭包初始化的存储属性。第二个是计算属性。
存储属性的初始化关闭仅被调用一次,但是您以后可以更改存储属性的值(除非用let替换var)。当您希望封装代码以在单个简洁的代码块中初始化存储的属性时,此功能很有用。
但是,每次引用变量时都会调用计算属性的块。当您希望每次引用计算属性时都调用代码时,此功能很有用。通常,当每次引用存储的属性时都需要重新计算计算的属性时(例如,从其他可能是私有的存储属性重新计算),您可以执行此操作。
在这种情况下,您无疑需要存储的属性(第一个示例),而不是计算的属性(第二个示例)。您大概每次引用该变量时都不需要新的推送行为对象。
顺便说一句,在第一个示例中,您内部引用了它的实例化。如果您想要这种行为,则必须使用lazy关键字:
lazy var pushBehavior: UIPushBehavior = {
let lazilyCreatedPush = UIPushBehavior()
lazilyCreatedPush.setAngle(50, magnitude: 50)
return lazilyCreatedPush
}()
但是,如果属性为static,则会自动延迟实例化。
很棒的解释.. !! ;)
关闭时间:
//closure
var pushBehavior: UIPushBehavior = {
let lazilyCreatedPush = UIPushBehavior()
lazilyCreatedPush.setAngle(50, magnitude: 50)
return lazilyCreatedPush
}()
第一次调用pushBehavior变量时,然后执行块,并将值保存在pushBehavior变量中。之后,无论何时调用pushBehavior,都将返回这些值。
表示仅执行并保存在此变量中的首次块代码。
同样,您可以随时存储变量值,但是此后,将返回那些值,但是如果您声明为" let",则无法更改此值。
计算属性:
var pushBehavior: UIPushBehavior {
get{
let lazilyCreatedPush = UIPushBehavior()
lazilyCreatedPush.setAngle(50, magnitude: 50)
return lazilyCreatedPush
}
}
在计算属性中,只要您调用pushBehavior变量,该块就会执行并返回值。因此,每个时间块都将执行。
并且您不能将变量声明为pushBehavior变量的" let"关键字。
因此,您可以根据需要使用此代码。
无论是否使用它,闭包一都会立即初始化。 它不是惰性地初始化。 顺便说一句,一段时间后将第一个单词大写,使阅读更愉快。
主要区别在于您无法为计算属性分配某些内容,因为它没有设置器。在这种情况下,闭包仅被调用一次,返回值存储在变量中,因此,如果结果不随时间变化,则使用存储的变量而不是计算出的变量会更有效。
通常,仅在可以快速检索值的情况下才应使用计算属性。
旁注:如果不更改/重新分配存储的变量,则应考虑使其成为常量(let)
这不是答案,但是值得一提:
初始化后必须知道存储的属性值。这可以通过默认设置或通过初始化来实现。
直到访问已计算属性的值,才进行计算
延迟加载的属性的值直到访问它才定义
因此,对于计算变量和惰性变量,您都可以访问self或存储的属性而无需担心。