iphone - 核心数据: does a fetch have to make a trip to persistent store?

标签 iphone objective-c ios core-data

假设我这样做:

NSManagedObjectContext *context = #a managed object context";
NSString *entityName = #an entity name#;
NSFetchRequest *requestForAll = [NSFetchRequest requestWithEntityName:entityName];
NSArray *allObj = [context executeFetchRequest:requestForAll];

for (NSString *name in allNamesArray){
    NSFetchRequest *requestForOne = [NSFetchRequest requestWithEntityName:entityName];
    requestForOne.predicate = [NSPredicate predicateWithFormat:@"name == %@",name];
    NSArray *ObjsWithName = [context executeFetchRequest:requestForOne];
    #do some work with the obj#
}

循环中的提取是否每次都会导致访问持久存储?或者这些提取只会在 coredata 的行缓存中执行?

编辑 我写了一段测试代码: 您需要创建一个名为“Person”的核心数据实体,它应该有一个名为“name”的属性,该属性的类型为字符串。

使用此代码填充一些数据:

self.array = @[@"alkjsdfkllaksjdf",@"asldjflkajdklsfjlk;aj",@"aflakjsdl;kfjalksdjfklajkldhkl;aj",@"aljdfkljalksdjfl;j" ,@"flajdl;kfjaklsdjflk;j",@"akldsjfklajdslkf",@"alkdjfkljaklsdjflkaj",@"alsdjflkajsdflj",@"adlkfjlkajsdfkljkla",@"alkdjfklajslkdfj"];

NSString *firstRunKey = @"oh its first run!";
NSString *firstRun = [[NSUserDefaults standardUserDefaults] objectForKey:firstRunKey];
if (!firstRun) {
    for (NSString *name in self.array) {
        Person *p = [NSEntityDescription insertNewObjectForEntityForName:@"Person" inManagedObjectContext:self.managedObjectContext];
        p.name = name;
    }
}
[self.managedObjectContext save];
[[NSUserDefaults standardUserDefaults] setObject:firstRunKey forKey:firstRunKey];
[[NSUserDefaults standardUserDefaults] synchronize];

分析这两种方法,你会发现使用CoreData比使用FilterArray花费更多的时间!

static int caseCount = 1000;
-(void)usingCoreData
{
    NSLog(@"core data");
    NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:@"Person"];
    NSArray *allPersons = [self.managedObjectContext executeFetchRequest:request error:nil];

    for (int i = 0; i < caseCount; i++){
        for (NSString *name in self.array) {
            request.predicate = [NSPredicate predicateWithFormat:@"name == %@",name];
            NSArray *result = [self.managedObjectContext executeFetchRequest:request error:nil];
        }
    }
}

-(void)usingFilterArray
{
    NSLog(@"filter array");
    NSFetchRequest *request = [[NSFetchRequest alloc] initWithEntityName:@"Person"];
    NSArray *allPersons = [self.managedObjectContext executeFetchRequest:request error:nil];

    for (int i = 0; i < caseCount; i++){
        for (NSString *name in self.array) {
            NSArray *array = [allPersons filteredArrayUsingPredicate:[NSPredicate predicateWithFormat:@"name == %@",name]];
        }
    }
}

最佳答案

我想我需要自己回答我的问题。

我测试了一下,发现每次执行fetch时,core data都会将你的NSFetchRequest翻译成SQL命令并调用数据库查询,查询结果首先是NSManagedObjectIDs,应用缓存从NSManagedObjectID中获取NSManagedObject。

综上所述,它缓存了对象,但不缓存查询结果。

这意味着您执行相同的 NSFetchRequest 10 次,它将查询您的持久存储 10 次,尽管您将获得 10 次相同的结果。所以在这种情况下,在内存中过滤数组会比获取更好。

关于iphone - 核心数据: does a fetch have to make a trip to persistent store?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13833529/

相关文章:

iphone - UIControl - 更改分配的选择器 : addTarget & removeTarget

iphone - UITextView : How to make scrollable?

objective-c - Swift 和 ScriptingBridge.framework

ios - 无法在另一个类的自定义类上设置 UIImageView.image

iOS 国际化与下载的图像

ios - 删除贝塞尔曲线路径之外

iphone - Game Center 不在排行榜 iPhone 中显示分数

iphone - iPhone 上的 XML 和 SQLite 内存利用率和性能

ios - 无法从 Parse 对象检索 updatedAt 或 createdAt 值

ios - 当应用程序处于后台但未挂起时如何处理推送通知