2013-04-26 50 views
0

我想我发现了一个NSError的错误,但想运行它通过你们,看看它实际上只是我做错了什么。发送描述到NSError

将描述发送到使用userInfo的NSError实例时发生崩溃。 如果userInfo设置为零,说明按预期工作。

NSString* const domain = @"DOMAIN"; 

NSError* nsError1 = [NSError errorWithDomain:domain code:1 userInfo:nil]; // Not using Dic 
NSLog(@"nsError1 description %@",[nsError1 description]); 

NSMutableDictionary* errorDetail = [NSMutableDictionary dictionary]; 
NSString* underlying = [NSString stringWithFormat:@"Error Domain=%@ Code=%d", NSPOSIXErrorDomain, 1]; 
[errorDetail setObject:underlying forKey:NSUnderlyingErrorKey]; 

NSError* nsError2 = [NSError errorWithDomain:domain code:1 userInfo:errorDetail]; // Useing Dic 
NSLog(@"nsError2 description %@",[nsError2 description]); // CRASH 

输出:

2013-04-26 22:36:03.703 CategoryTest[14271:11303] nsError1 description Error Domain=DOMAIN Code=1 "The operation couldn’t be completed. (DOMAIN error 1.)" 
2013-04-26 22:37:30.459 CategoryTest[14271:11303] -[__NSCFString localizedDescription]: unrecognized selector sent to instance 0x901cca0 
+5

那么,根据文档,'NSUnderlyingErrorKey'应该有一个NSError对象。所以我不明白这是一个错误。 – Mats 2013-04-26 21:58:53

回答

3

这是你的代码错误,而不是苹果的一个bug。记录为NSUnderlyingErrorKey的对象具有对应的值NSError。你的代码应该这样做:

NSError *underlying = [NSError errorWithDomain:NSPOSIXErrorDomain code:1 userInfo:nil];