1

我正在使用 MagicalRecord 库加载一些用于填充 tableview 的 CoreData 对象。这是一个缓慢的操作,因此我试图在后台威胁上执行此操作。这一切似乎都很顺利,数据被加载到self.products,只有在一段时间(+-分钟)之后,所有加载的对象似乎都进入了<fault>状态。我不明白为什么会这样,有人知道吗?

- (void)doInBackground
{
 dispatch_queue_t myQueue = dispatch_queue_create("com.mycompany.myqueue", 0);
    dispatch_async(myQueue, ^{
        [self reloadData];

        dispatch_sync(dispatch_get_main_queue(), ^{

            [MBProgressHUD hideHUDForView:self.view animated:YES];
            [self performSelectorOnMainThread: @selector(sortData:) withObject:self waitUntilDone:YES];

        });
    });
}

- (void)reloadData
{
 NSArray *allProducts = [NSArray array];    
 allProducts =   [NSArray arrayWithArray:[Product MR_findAll]];
 self.products = [NSArray arrayWithArray:allProducts];
} 
4

1 回答 1

3

首先,您通过仅使用 MR_findAll 而不指定上下文来隐式使用默认上下文。这最终会导致崩溃或其他未知行为。其次,您不需要所有这些 NSArray。MR_findAll(和所有其他 MR_find* 方法)的返回值返回一个结果数组。无需将内容从一个数组移动到另一个数组...

最后,你的问题。因为您正在主上下文队列上进行提取,所以无论如何您的提取都会阻止 UI。您需要创建一个 Private Queue 上下文并使用它执行您的提取,如下所示:

NSManagedObjectContext *privateQueueContext = [NSManagedObjectContext MR_privateQueueContext];
NSArray *results = [Product MR_findAllInContext:privateQueueContext];

此外,您可能想研究批量获取。查看有关获取获取请求的文档,如下所示:

NSFetchRequest *request = [Product MR_requestAllInContext:privateQueueContext];
//update batch size here

MagicalRecord 在内部设置了批量大小,但如果您需要更改它,这就是您这样做的方式。

于 2013-09-01T16:33:53.023 回答