ios - 如何调试和重现 `NSOperationQueue`崩溃

标签 ios objective-c crash nsoperationqueue eventkit

在我的基于日历的应用程序中,我面临着来自应用程序商店构建的大量崩溃。但是,我无法重现,也没有遇到开发过程中的崩溃。

来自 Fabric 的崩溃日志:

-[EKEventStore(Utils) calendarByRetrievingSafelyWithIdentifier:forEntityType:]

    Crashed: NSOperationQueue 0x17403fd60 :: NSOperation 0x17425bfc0 (QOS: DEFAULT)
0  CoreFoundation                 0x19179b5d8 -[__NSDictionaryM setObject:forKey:] + 476
1  EventKit                       0x19ab2a0d8 -[EKObject relationForKey:] + 216
2  EventKit                       0x19ab859d4 -[EKCalendar source] + 24
3  EventKit                       0x19ab9d718 -[EKEventStore calendarsForEntityType:] + 512
4  SampleApp                       0x100112554 -[EKEventStore(Utils) calendarByRetrievingSafelyWithIdentifier:forEntityType:] (MySampleCalendarStore.m:4767)
5  SampleApp                       0x1001d3f88 -[MyCalendarDataStore syncCalendarItems:startDate:endDate:completion:] (MyCalendarDataStore.m:84)
6  SampleApp                       0x1000f4e58 __62-[MySampleAppStore syncDeviceCalendarsAndItems:withCompletion:]_block_invoke.1043 (MySampleCalendarStore.m:2499)
7  Foundation                     0x19237e754 __NSBLOCKOPERATION_IS_CALLING_OUT_TO_A_BLOCK__ + 16
8  Foundation                     0x1922c32c8 -[NSBlockOperation main] + 96
9  Foundation                     0x1922b38c4 -[__NSOperationInternal _start:] + 620
10 Foundation                     0x192380b00 __NSOQSchedule_f + 228
11 libdispatch.dylib              0x1907451c0 _dispatch_client_callout + 16
12 libdispatch.dylib              0x190753444 _dispatch_queue_serial_drain + 928
13 libdispatch.dylib              0x1907489a8 _dispatch_queue_invoke + 652
14 libdispatch.dylib              0x19075538c _dispatch_root_queue_drain + 572
15 libdispatch.dylib              0x1907550ec _dispatch_worker_thread3 + 124
16 libsystem_pthread.dylib        0x19094e2b8 _pthread_wqthread + 1288
17 libsystem_pthread.dylib        0x19094dda4 start_wqthread + 4

我想解决这个崩溃问题,我上周在所有论坛上都尝试过。我找不到任何有用的线索来解决我的问题。 请指导我手动重现此类崩溃并帮助解决。

我的代码:

NSOperationQueue *calendarDataStoresQueue = [[NSOperationQueue alloc] init];
for (EKCalendar *calendar in calendars) {
        [calendarDataStoresQueue addOperationWithBlock:^{
            MyCalendarDataStore *calendarDataStore = [[MyCalendarDataStore alloc] initWithCalendar:[[MYCalendar alloc] initWithInfoOfEventKitCalendar:calendar] eventStore:weakSelf.eventStore];
            [calendarDataStore syncCalendarItems:items startDate:syncFrom endDate:syncTo completion:^{
                complition()
            }];
        }];
}

我的实用工具:

@implementation EKEventStore (Utils)

- (EKCalendar*)calendarByRetrievingSafelyWithIdentifier:(NSString *)identifier forEntityType:(EKEntityType)entityType {
    EKCalendar *calendar;
    NSArray *calendars = [self calendarsForEntityType:entityType];
    for (EKCalendar *aCalendar in calendars) {
        if([aCalendar.calendarIdentifier isEqualToString:identifier]) {
            calendar = aCalendar;
            break;
        }

    }
    return calendar;
}
@end

提前致谢

最佳答案

您没有发布足够的信息;你在 -[EKObject relationForKey:] 方法内的某个地方发生了崩溃;更重要的是,您还没有发布崩溃的确切原因;

在我看来,这个方法 [EKObject relationForKey:] 在某个地方从自身生成 dict,并且可能是 [__NSDictionaryM setObject:forKey:] 在这里你尝试将 nil 插入 dict

关于ios - 如何调试和重现 `NSOperationQueue`崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40743107/

相关文章:

ios - objective-c : unrecognized selector sent to instance 0x6080000550c0

ios - 正则表达式负向前瞻和后向查找未嵌入包装器中的字符

ios - 为什么 Xcode 7 显示 *.tbd 而不是 *.dylib?

ios - 在 XCode 中收到关于 NSMutableDictionary 键应该是 NSNumber 的警告

objective-c - 当前目录路径和 NSTask

iphone - 无法使用 NSDateFormatter 格式化 UTC 日期

php - 从 PHP 运行脚本时,RPi GPIO 控制丢失(没有任何错误)

ios - 在 Swift 的数组中使用多个部分和多个字典填充 TableView

ios - 在 obj c - ios 中使用 C Dll 和 lib

ios - Mapbox iOS SDK 动态样式坐标边界崩溃