php计算属性集的闭包,关于swift:计算属性与带闭包的属性集之间的区别
我是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或存儲的屬性而無需擔心。
總結
以上是生活随笔為你收集整理的php计算属性集的闭包,关于swift:计算属性与带闭包的属性集之间的区别的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 中电福富是国企吗
- 下一篇: 战地国服下架了(战地ol为什么关服)