swift:将存储的属性用作计算属性是正确的

Man*_*ani 6 ios swift

我试图实现这个Objective-c代码

@property (strong) UIView *customView;

-(UIView*)customView
{
   if (!customView){
       self.customView = [[UIView alloc]init];
       self.customView.backgroundColor = [UIColor blueColor];
  }
   return customView;
}
Run Code Online (Sandbox Code Playgroud)

我为什么要用这个?从很多地方调用customView,所以我们必须在所有地方检查这个条件.为了避免这种重复,我写了这个.

所以我尝试创建存储的属性,并使用getter方法检查是否已创建.

var mainView : UIView? {

  get{
   if let customView = self.mainView{
        return self.mainView
   }
   var customView : UIView = UIView() 
   self.mainView = customView
   self.mainView.backgroundColor = UIColor(blueColor)
   return customView 
 }
 set{
  self.mainView = newValue
  }
}
Run Code Online (Sandbox Code Playgroud)

它是否正确?或任何其他方法来做到这一点?

注意:上述代码没有警告或错误.但与存储和计算属性混淆.请说清楚.

las*_*sej 13

不确定原因,但是与计算属性结合的惰性变量会导致错误:

'lazy' attribute may not be used on a computed property
Run Code Online (Sandbox Code Playgroud)

但这似乎有效:

class MyClass {
  @lazy var customView: NSView = {
    let view = NSView()
    // customize view
    return view
  }()
}
Run Code Online (Sandbox Code Playgroud)

  • @MikePollard虽然计算属性是在访问时计算的,但它没有被记忆,即它的返回值没有被保存.因此,每次访问它时都会计算计算属性*.我不会称之为懒惰.另一方面,懒惰的存储属性仅在第一次被访问时计算,因为它被记忆,因此,每次后续访问只返回保存的值. (14认同)
  • 我猜计算属性本质上是懒惰的.它们在被访问时而不是之前被计算出来. (2认同)