单线程保存上的iOS7 NSMergeConflict

前端之家收集整理的这篇文章主要介绍了单线程保存上的iOS7 NSMergeConflict前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在重新排序两行之后,在单线程应用程序上存在简单数据保存问题.

我已经设法简化了编码以重现错误,并希望与其他人一起尝试这一点的第二意见.

这是一个完整性检查,因为我怀疑iOS 7引入的核心数据问题,因为这在iOS 6中运行正常.

首先,启动一个新的核心数据项目并创建这个模型……

属性’current’是可选的布尔值.一对多关系是有序关系,创建NSOrderedDataset.

现在为应用添加几个按钮;第一个创建数据(一个项目和两个相关的’图纸’),第二个交换两个图纸,然后在第一个图纸中设置一个属性.

这是代码……

  1. -(IBAction)onTestButton:(id)sender
  2. {
  3. id delegate = [[UIApplication sharedApplication]delegate];
  4. NSManagedObjectContext *managedObjectContext = [delegate managedObjectContext];
  5.  
  6. self.project = [NSEntityDescription insertNewObjectForEntityForName:@"Project" inManagedObjectContext:managedObjectContext];
  7. Drawing *drawing1 = [NSEntityDescription insertNewObjectForEntityForName:@"Drawing" inManagedObjectContext:managedObjectContext];
  8. Drawing *drawing2 = [NSEntityDescription insertNewObjectForEntityForName:@"Drawing" inManagedObjectContext:managedObjectContext];
  9.  
  10. NSMutableOrderedSet* tempSet = [NSMutableOrderedSet orderedSetWithOrderedSet:self.project.drawings];
  11. [tempSet addObject:drawing1];
  12. [tempSet addObject:drawing2];
  13. self.project.drawings = tempSet;
  14.  
  15. [self save];
  16. }
  17.  
  18. -(IBAction)onTestButton2:(id)sender
  19. {
  20. NSMutableOrderedSet *exchange = [self.project mutableOrderedSetValueForKey:@"drawings"];
  21. [exchange exchangeObjectAtIndex:0 withObjectAtIndex:1];
  22. self.project.drawings = exchange;
  23.  
  24. [self save];
  25.  
  26. Drawing *drawing = [self.project.drawings objectAtIndex:0];
  27.  
  28. BOOL current = [drawing.current boolValue];
  29. drawing.current = [NSNumber numberWithBool:!current];
  30.  
  31. [self save];
  32. }
  33.  
  34. -(void)save
  35. {
  36. id delegate = [[UIApplication sharedApplication]delegate];
  37. NSManagedObjectContext *managedObjectContext = [delegate managedObjectContext];
  38. NSError *error = nil;
  39.  
  40. if( ![managedObjectContext save:&error] )
  41. {
  42. NSLog(@"%@ Save: Unresolved Error on Save %@",error,[error userInfo] );
  43. abort();
  44. }
  45. }

现在,按第一个测试按钮进行测试.这会设置数据.

然后按第二个测试按钮……一切OK!

现在再次按下第二个测试按钮并弹出.您应该得到类似于此的NSMergeConflict错误….

Save: Unresolved Error on Save {
conflictList = (
“NSMergeConflict (0x8a7d0b0) for NSManagedObject (0x8bedfa0) with objectID ‘0x8bd9340
‘ with
oldVersion = 1 and newVersion = 2 and old object snapshot = {\n
current = \”\”;\n project = \”0x8bc3f50
\”;\n}
and new cached row = {\n current = \”\”;\n project =
\”0x8aa88c0
\”;\n}”
);

我从错误中注意到我的Project对象已经改变.但是,这是使用主应用程序上下文的单线程应用程序.

我花了太长时间在这上面,并希望其他人就问题所在地发表评论.这是一个核心数据错误,还是我是一个正确的’傻瓜’?

非常感谢

/适合

解决方法

我有类似的问题,找到了一个解决方法

http://prod.lists.apple.com/archives/cocoa-dev/2013/Oct/msg00657.html

简而言之 – 将其添加到您的MOC设置中:

  1. [_managedObjectContext setMergePolicy:[[NSMergePolicy alloc] initWithMergeType:NSMergeByPropertyObjectTrumpMergePolicyType]];

当使用NSsqlStoreType时,这也会影响OS X 10.9 Mavericks.我无法使用NSXMLStoreType重复合并错误.

对于Swift 2.x

  1. managedObjectContext.mergePolicy = NSMergePolicy(mergeType: .MergeByPropertyObjectTrumpMergePolicyType)

猜你在找的iOS相关文章