objective-c – NSStringFromClass([MyEntityClass类])是否生成安全的Core Data Entity名称?

大多数(我所看到的)Core Data教程使用以下代码片段:@“MyEntityClass”,硬编码:
NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:@"MyEntityClass"];

使用NsstringFromClass()作为实体名称是否安全?

NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:NsstringFromClass([MyEntityClass class])];

这个接缝在重构等方面要更容易处理.特别是因为我有Xcode创建我的NSManagedobject子类.我问,因为我从来没有见过这个,所以也许我错过了一些东西.

解决方法

是的,如果您的实体的类在模型中设置为MyEntityClass,则该代码是正确的.

我更喜欢给实体类一个返回实体名称的类方法

+ (Nsstring *)entityName {
    return NsstringFromClass(self);
}

并称之为:

NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:[MyEntityClass entityName]];

这样,如果我想更改类名,而不改变模型中的实体名称,我可以在类方法中进行更改:

+ (Nsstring *)entityName {
    return @"NewEntityName";
}

我为什么要这么做?那么我可以为实体决定一个更好的名字.更改类名称不会破坏与现有Core Data持久存储的兼容性,而是更改模型文件中的实体名称.我可以更改类名称和entityName方法,但是在模型中保留实体名称不变,然后我不必担心迁移. (轻量级迁移支持重命名实体,所以它不是一个很大的交易.)

您可以进一步,实际上使用entityName方法在运行时从托管对象模型查找实体名称.假设你的应用程序委托有一个返回管理对象模型的消息:

+ (Nsstring *)entityName {
    static Nsstring *name;
    static dispatch_once_t once;
    dispatch_once(&once,^{
        Nsstring *myName = NsstringFromClass(self);
        NSManagedobjectModel *model = [(AppDelegate *)[UIApplication delegate] managedobjectModel];
        for (NSEntityDescription *description in model.entities) {
            if ([description.managedobjectClassName isEqualToString:myName]) {
                name = description.name;
                break;
            }
        }
        [NSException raise:NSinvalidargumentexception
            format:@"no entity found that uses %@ as its class",myName];
    });
    return name;
}

显然,如果你真的想这样做,你应该将dispatch_once块的内容放在一个帮助方法中,大概在你的应用程序委托(或者你获得该模型的地方).

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...