我已将所有 NSManagedObject 的自定义逻辑放在一个类别中,这样当模型发生变化时,我可以从模型中重新生成标准类。
我需要的一个这样的逻辑是对象属性之一的自定义 setter :
- (void) setNameNSString *)name
{
[self willChangeValueForKey"name"];
[self setPrimitiveValue:name forKey"name"];
[self didChangeValueForKey"name"];
NSLog(@"name was changed");//for example
}
我已将其放在类别中,在本例中为 Item+Custom.m
我的问题:
为什么每当我设置一个Item的名称时,不需要导入Item+Custom.m?上面的日志语句仍然会触发。
只是好奇发送消息的类如何不需要知道类别才能使逻辑仍然触发?
并且(也许是一个单独的问题)如果我将具有不同日志记录语句的相同自定义 setter 添加到同一对象的第二个类别会发生什么?
Best Answer-推荐答案 strong>
加载程序时,所有类别方法都会被运行时知道。所以如果你声明了一个-[Item setName:] 方法,那么Core Data就不会再在运行时创建这个方法了。
您无需导入任何内容,因为 name 已在 Xcode 生成的托管对象子类文件中声明为 @dynamic 属性。
如果两个类别声明了相同的方法,或者如果一个类别中声明的方法名称与原始类中的方法相同,则行为未定义,请参阅 Avoid Category Method Name Clashes在“使用 Objective-C 编程”中。
关于ios - 类别中的自定义 NSManagedObject setter ,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/15145309/
|