Stored 属性 需要一个初始值或者应该是@NSManaged
Stored property requires an initial value or should be @NSManaged
我正在尝试转换 Apple's sample code 以创建核心数据的自定义部分标识符,以便正确地 sort/label 来自 Objective-C 的 table 视图中的部分进入 Swift。他们为声明为 @dynamic
的非瞬态 属性 实现了 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
中,这对于第一次启动确实非常有效 - 我可以创建一个对象并将其存储并在 table 的适当部分中查看。但是在随后的启动中,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:如果你想为你的计算属性设置 属性 个观察者,你可以将你 类 子类化并添加 属性 个观察者到继承的属性。
我正在尝试转换 Apple's sample code 以创建核心数据的自定义部分标识符,以便正确地 sort/label 来自 Objective-C 的 table 视图中的部分进入 Swift。他们为声明为 @dynamic
的非瞬态 属性 实现了 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
中,这对于第一次启动确实非常有效 - 我可以创建一个对象并将其存储并在 table 的适当部分中查看。但是在随后的启动中,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:如果你想为你的计算属性设置 属性 个观察者,你可以将你 类 子类化并添加 属性 个观察者到继承的属性。