アプリ ユーザーのサブセットがクラッシュを報告しています。彼らのクラッシュ ログの 1 つをシンボル化したところ、問題のあるコードが読み取られたラベルであることがわかりました。
クラッシュ ログからの出力は次のとおりです。
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);
この最後の行がどのようにクラッシュを引き起こすのか理解できません。なぜなら、それがカウント未満であり、ゼロから始まることを検証したからです。
これは私を少し夢中にさせているので、どんなアイデアでも大歓迎です!