0

在阅读了 swift 中的 @property/@synthesize 等效项后,我开始好奇 Objective C 的功能是如何保留的。

假设我在目标 C 中有以下内容:

@interface MyClass
@property (readwrite) MyType *myVar;
@end

这可以使用基于点和 smalltalk 的语法来访问:

Type *newVar1 = myClassInstance.myVar;
Type *newVar2 = [myClassInstance myVar];

myClassInstance.myVar = newVar1;
[myClassInstance setMyVar: newVar2];

如果我想为这些 getter/setter 添加一些额外的功能,我可以这样做:

@implementation MyClass

- (MyType *) myVar
{
    // do more stuff
    return self._myVar;
}

- (void) setMyVar: (MyType *) newVar
{
    self._myVar = newVar;
    // do more stuff
}

@end

(另请参阅@property 的自定义设置器?

但是,上述链接问题的公认答案表明 Swift 不区分属性和实例变量。所以,假设我在 Swift 中有以下内容:

class MyClass {
    var myVar: MyType
}

据我所知,访问的唯一方法myVar是:

var newVar1 = myClassInstance.myVar;

myClassInstance.myVar = newVar1;

但我不知道如何自定义这些 getter 和 setter。是否有 Swift 等效的 Objective C@property覆盖?

4

1 回答 1

0

在研究这个问题时,我实际上偶然发现了我的答案,但仍然认为应该把它放在这里给有同样问题的其他人。


是的,根据Swift Programming Language 文档中关于 Properties 的页面,getter 和 setter 的制作方式与 C# 解决问题的方式类似:

struct MyParentType {
    var myPlainVar: MyType = MyType()
    
    var myCustomGetterVar: MyType {
        // do more stuff
        return self.myCustomGetterVar
    }
    
    var myCustomGetterSetterVar: MyType {
        get {
            // do more stuff
            return self.myCustomGetterSetterVar
        }
        set {
            // do stuff
            self.myCustomGetterSetterVar = newValue
            // do more stuff
        }
    }
    
    var myCustomFancyVar: MyType? {
        willSet {
            // do stuff with newValue
        }
        // actual setting is done automatically, so no set{}
        didSet {
            // do more stuff with oldValue
        }
    }
}

请注意,变量 withdidSet必须是初始化的或可选的,并且不能有 a get,因为计算的属性get可以很容易地实现它们自己的didSetwillSet如果他们愿意的话。

于 2015-04-01T16:23:23.263 回答