我正在尝试转换 Apple's sample code用于为核心数据创建自定义部分标识符,以便将 TableView 中的部分从 Objective-C 正确排序/标记到 Swift 中。他们为声明为 @dynamic
的非 transient 属性实现了一个 setter,因此他们可以在时间更改时使标识符无效。我以为我会在 @NSManaged
属性上使用 didSet
,但是 Xcode 抛出一个错误:Stored property requires an initial value or should be @NSManaged
.
如何适本地转换以获得所需的行为?
@property (nonatomic) NSDate *primitiveTimeStamp;
@property (nonatomic) NSString *primitiveSectionIdentifier;
@dynamic title, timeStamp, primitiveTimeStamp, sectionIdentifier, primitiveSectionIdentifier;
- (void)setTimeStamp:(NSDate *)newDate {
// If the time stamp changes, the section identifier become invalid.
[self willChangeValueForKey:@"timeStamp"];
[self setPrimitiveTimeStamp:newDate];
[self didChangeValueForKey:@"timeStamp"];
[self setPrimitiveSectionIdentifier:nil];
}
我试过:
var primitiveTimeStamp: NSDate?
var primitiveSectionIdentifier: String?
@NSManaged var timeStamp: NSDate { //error here
didSet {
self.willChangeValueForKey("timeStamp")
self.primitiveDate = timeStamp
self.didChangeValueForKey("timeStamp")
self.primitiveSectionIdentifier = nil
}
}
我也试过取消@NSManaged
,只使用var timeStamp: NSDate!
,然后将代码放在didSet
中,这实际上第一次启动时效果很好——我可以创建一个对象并将其存储并在表的适当部分中查看它。但在随后的启动中,timeStamp
属性为 nil
,因此应用程序在尝试生成 sectionIdentifier
时崩溃。
最佳答案
timeStamp
您定义的是存储属性而不是计算属性。计算属性可能没有 didSet/didGet 观察者。
You don't need to define property observers for non-overridden computed properties, because you can observe and respond to changes to their value from directly within the computed property's setter.
var primitiveTimeStamp: NSDate?
var primitiveSectionIdentifier: String?
var timeStamp: NSDate {
get {
return self.primitiveDate
}
set {
self.willChangeValueForKey("timeStamp")
self.primitiveDate = newValue
self.didChangeValueForKey("timeStamp")
self.primitiveSectionIdentifier = nil
}
}
由于计算属性应该只有一个 getter,或者同时具有 setter/getter,因此您还必须设置 getter。
我没有测试代码,但它们可能会解决您的问题。
PS:如果你想为你的计算属性设置属性观察器,你可以将你的类子类化并将属性观察器添加到继承的属性中。
关于ios - 存储的属性需要一个初始值或者应该是@NSManaged,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29452857/