无法识别的选择器通过Coredata Swift发送到实例

无法识别的选择器通过Coredata Swift发送到实例,第1张

无法识别的选择器通过Coredata Swift发送到实例

好的,因此得到错误的原因很可能是因为所引用的对象

self.habit
不是
Habit
对象。找出对象实际的最简单方法是调用:

print(NSStringFromClass(habit.class))

对于核心数据和自定义,

NSManagedObjects
您需要确保实体:“习惯”(在数据模型中)具有设置为“习惯”的类。这可以确保Core
Data将具有“
Habit”的实体描述的获取的对象强制转换为Habit类。如果您不这样做,则
getHabits
函数将返回
NSManagedObject
s
的数组而不是s的数组。
Habit
如果是这种情况,则代码:
println(NSStringFromClass(habit.class))
将向调试器输出“
NSManagedObject”。

附带说明,从Core Data数据库获取对象时,您确实需要检查错误。添加行:

if objects? == nil {    print("An error occurred error.localisedDescription")}

如果有任何错误,请原谅我,我通常使用Objective-C。

编辑:为了纠正

Failed to call designated initializer on NSManagedObject class'X'
错误。如果未正确实例化,则会引发此错误
NSManagedObject
。您一定不能打电话
[[MyManagedObject alloc]init];
initWithEntity:insertIntoManagedObjectContext
而必须打电话:

MyManagedObject *obj = [[MyManagedObject alloc] initWithEntity:[NSEntityDescription entityForName:@"MyManagedObject" inManagedObjectContext:context] insertIntoManagedObjectContext:context];

如果您不希望将对象

obj
插入上下文,则可以通过
nil
上下文参数传递。但是,如果要撤消管理并具有将对象保存到数据库的功能,则需要将其与上下文关联。

如果要自定义对象的初始化,则可以覆盖

awakeFromInsert
awakeFromFetch
方法/函数。



欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4974011.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-13
下一篇 2022-11-13

发表评论

登录后才能评论

评论列表(0条)

保存