[图像计数]:发送到实例的无法识别的选择器
Posted
技术标签:
【中文标题】[图像计数]:发送到实例的无法识别的选择器【英文标题】:[Image count]: unrecognized selector sent to instance 【发布时间】:2013-12-17 12:45:43 【问题描述】:保存managedObjectContext
时出现以下错误:
Terminating app due to uncaught exception 'NSInvalidArgumentException',
reason: '-[Image count]: unrecognized selector sent to instance
代码:
- (void)imagePickerController:(UIImagePickerController *)picker didFinishPickingImage:(UIImage *)selectedImage editingInfo:(NSDictionary *)editingInfo
// Delete any existing image.
Image *oldImage = _place.image;
if (oldImage != nil)
[_place.managedObjectContext deleteObject:oldImage];
Image *image = [NSEntityDescription insertNewObjectForEntityForName:@"Image" inManagedObjectContext:_place.managedObjectContext];
image.imageData = UIImageJPEGRepresentation(selectedImage, 0.5);
_place.image = image;
[_place.managedObjectContext save:nil]; //Here is the crash
[self dismissViewControllerAnimated:YES completion:nil];
Image
实体有两个一对一的关系:place
和 trip
。
@interface Image : NSManagedObject
@property (nonatomic, retain) NSData * imageData;
@property (nonatomic, retain) Trip *trip;
@property (nonatomic, retain) Place *place;
@end
不明白为什么[Image count]
错误出现在一对一的关系上。
更新:
@interface Place : NSManagedObject
@property (nonatomic, retain) NSString * address;
@property (nonatomic, retain) NSString * name;
@property (nonatomic, retain) id thumbnail;
@property (nonatomic, retain) Image *image;
@end
更新.2:
*** First throw call stack:
(
0 CoreFoundation 0x022935e4 __exceptionPreprocess + 180
1 libobjc.A.dylib 0x01cef8b6 objc_exception_throw + 44
2 CoreFoundation 0x02330903 -[NSObject(NSObject) doesNotRecognizeSelector:] + 275
3 CoreFoundation 0x0228390b ___forwarding___ + 1019
4 CoreFoundation 0x022834ee _CF_forwarding_prep_0 + 14
5 CoreData 0x00803df8 -[NSSQLCore _knownOrderKeyForObject:from:inverseToMany:] + 200
6 CoreData 0x0073ad50 -[NSSQLCore _populateRowForOp:withObject:] + 1120
7 CoreData 0x00750e27 -[NSSQLCore recordValuesForInsertedObject:] + 71
8 CoreData 0x00739b5d -[NSSQLCore recordChangesInContext:] + 685
9 CoreData 0x00738925 -[NSSQLCore saveChanges:] + 565
10 CoreData 0x0070555c -[NSSQLCore executeRequest:withContext:error:] + 412
11 CoreData 0x00705050 -[NSPersistentStoreCoordinator executeRequest:withContext:error:] + 4704
12 CoreData 0x00731ccc -[NSManagedObjectContext save:] + 764
13 Travel Plan 0x0001cf12 -[PlaceViewController imagePickerController:didFinishPickingImage:editingInfo:] + 738
14 UIKit 0x00cd5e6c -[UIImagePickerController _imagePickerDidCompleteWithInfo:] + 488
15 PhotoLibrary 0x13694e94 PLNotifyImagePickerOfImageAvailability + 106
16 PhotosUI 0x14411585 -[PUUIPhotosAlbumViewController handleNavigateToAsset:inContainer:] + 401
17 PhotosUI 0x143947b4 -[PUPhotosGridViewController collectionView:shouldSelectItemAtIndexPath:] + 577
18 UIKit 0x0106dc0b -[UICollectionView _selectItemAtIndexPath:animated:scrollPosition:notifyDelegate:] + 173
19 UIKit 0x010861f8 -[UICollectionView _userSelectItemAtIndexPath:] + 189
20 UIKit 0x010863b5 -[UICollectionView touchesEnded:withEvent:] + 437
21 libobjc.A.dylib 0x01d01874 -[NSObject performSelector:withObject:withObject:] + 77
22 UIKit 0x00bb6902 forwardTouchMethod + 271
23 UIKit 0x00bb6972 -[UIResponder touchesEnded:withEvent:] + 30
24 libobjc.A.dylib 0x01d01874 -[NSObject performSelector:withObject:withObject:] + 77
25 UIKit 0x00bb6902 forwardTouchMethod + 271
26 UIKit 0x00bb6972 -[UIResponder touchesEnded:withEvent:] + 30
27 libobjc.A.dylib 0x01d01874 -[NSObject performSelector:withObject:withObject:] + 77
28 UIKit 0x00bb6902 forwardTouchMethod + 271
29 UIKit 0x00bb6972 -[UIResponder touchesEnded:withEvent:] + 30
30 UIKit 0x00dd1c7f _UIGestureRecognizerUpdate + 7166
31 UIKit 0x00a9c19a -[UIWindow _sendGesturesForEvent:] + 1291
32 UIKit 0x00a9d0ba -[UIWindow sendEvent:] + 1030
33 UIKit 0x00a70e86 -[UIApplication sendEvent:] + 242
34 UIKit 0x00a5b18f _UIApplicationHandleEventQueue + 11421
35 CoreFoundation 0x0221c83f __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 15
36 CoreFoundation 0x0221c1cb __CFRunLoopDoSources0 + 235
37 CoreFoundation 0x0223929e __CFRunLoopRun + 910
38 CoreFoundation 0x02238ac3 CFRunLoopRunSpecific + 467
39 CoreFoundation 0x022388db CFRunLoopRunInMode + 123
40 GraphicsServices 0x046299e2 GSEventRunModal + 192
41 GraphicsServices 0x04629809 GSEventRun + 104
42 UIKit 0x00a5dd3b UIApplicationMain + 1225
43 Travel Plan 0x0004c53d main + 141
44 libdyld.dylib 0x02dd170d start + 1
)
【问题讨论】:
请同时显示地点的定义 @Daij-Djan 我现在就添加它。 如果您在异常上设置断点,那么以[Image count]
结尾的跟踪是什么样的?
inverseToMany:
看起来确实很可疑。您是否曾经从代码中删除了一对多关系但仍然存在于模型中?或者模型的一些缓存部分没有被清理? (我知道这是一个长镜头,但我会尝试一个完整的“清理”和“删除派生数据”,看看是否有什么不同步。)
以及来自 MOM 的相关实体定义?看起来 CD 认为它应该是一组图像或其他东西
【参考方案1】:
在更改模型中的某些关系后,我遇到了完全相同的问题。这似乎是 Xcode 中的一个错误,当您将“to many : ordered”关系更改为“to one”关系时出现。就像 Xcode 仍然认为关系是多的,因为“有序”复选框被勾选了。
解决此问题的一个非常简单的解决方案是改回“对多”关系,取消选择“有序”,然后再次将其改回“对一”关系。
【讨论】:
你是救世主哈哈 :) 我已经检查这个很久了。【参考方案2】:这是 Xcode 中的一些错误。将关系设置为多个,然后再返回一个,它开始正常工作。
【讨论】:
我也遇到过这样的问题。通过从模型中删除“损坏的”实体(包括所有关系)、构建项目然后从头开始创建它来解决它。 Médéric Petit 的回答比 zakhej 的回答更快、更有效。我建议先尝试一下,它对我来说就像一个魅力。 @pallzoltan 他写的和我一模一样,差不多 6 个月后。 @Shmidt,他提到取消选中 Ordered 复选框,这会有所不同。我已经按照你的建议做了,直到我取消了 Ordered 复选框,它才起作用;)以上是关于[图像计数]:发送到实例的无法识别的选择器的主要内容,如果未能解决你的问题,请参考以下文章
[UICollectionViewCell imageView]:无法识别的选择器发送到实例
NSInvalidArgumentException,使用 performSegueWithIdentifier 时发送到实例的无法识别的选择器