我的一部分应用用户报告了崩溃。当我符号化他们的一个崩溃日志时,我发现有问题的代码是读取的标签。
以下是崩溃日志的输出:
Exception Type: EXC_BAD_ACCESS (SIGSEGV)
Exception Codes: KERN_INVALID_ADDRESS at 0x00000000
Crashed Thread: 0
Thread 0 name: Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0 CoreFoundation 0x33e5004e 0x33e4d000 + 12366
1 CoreFoundation 0x33e58cfc 0x33e4d000 + 48380
2 Mail my meeting 0x00002a9c -[Mail_my_meetingAppDelegate initPeople] Mail_my_meetingAppDelegate.m:136)
3 Mail my meeting 0x0000287a -[Mail_my_meetingAppDelegate application:didFinishLaunchingWithOptions:] (Mail_my_meetingAppDelegate.m:74)
这是代码,第 136 行是最后一行:
NSString* finalName=[NSString stringWithFormat:@"%@%@%@",firstName,middleName,lastName];
NSString *phoneNumber = nil;
ABMultiValueRef phoneNumbers1 = ABRecordCopyValue(person,kABPersonPhoneProperty);
if (ABMultiValueGetCount(phoneNumbers1) > 0) {
CFIndex j;
for (j=0; j < ABMultiValueGetCount(phoneNumbers1); j++) {
CFStringRef label = ABMultiValueCopyLabelAtIndex(phoneNumbers1, j);
我无法理解最后一行如何导致崩溃,因为我验证它小于计数,并且它从零开始。
这让我有点发疯,所以欢迎任何想法!