//closure var pushBehavior: UIPushBehavior = { let lazilyCreatedPush = UIPushBehavior() lazilyCreatedPush.setAngle(50,magnitude: 50) return lazilyCreatedPush }()
与
//computed var pushBehavior: UIPushBehavior { get{ let lazilyCreatedPush = UIPushBehavior() lazilyCreatedPush.setAngle(50,magnitude: 50) return lazilyCreatedPush } }第一个是通过闭包初始化的存储属性。第二个是计算属性。
因此,存储属性的初始化关闭被调用一次,只能调用一次,然后可以稍后更改存储属性的值(除非用let替换var)。但是,每次引用变量时,都会调用计算属性的块。
在这种情况下,您无疑希望存储的属性(第一个示例),而不是计算的属性(第二个示例)。你可能不想在每次引用变量时都需要一个新的push行为对象。
顺便说一句,在你的第一个例子中,你内部参考它被实例化了。如果你想要这个行为,你必须使用lazy关键字:
lazy var pushBehavior: UIPushBehavior = { let lazilyCreatedPush = UIPushBehavior() lazilyCreatedPush.setAngle(50,magnitude: 50) return lazilyCreatedPush}()总结
以上是内存溢出为你收集整理的swift – 计算属性和属性设置与闭包之间的差异全部内容,希望文章能够帮你解决swift – 计算属性和属性设置与闭包之间的差异所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)