FMDBBlockSQLiteCallBackFunction Сбой в приложении, которое не использует makeFunctionNamed

96

Я работаю над приложением, которое в магазине приложений, которое использует FMDB для взаимодействия с его базой данных sqlite. Мы получили несколько отчетов о сбоях со следами стека, такими как:

Thread : Crashed: NSOperationQueue 0x170239c20 :: NSOperation 0x17024d7d0 (QOS: LEGACY)
0  libobjc.A.dylib                0x000000019701c0b4 objc_retain + 20
1  MyApp                          0x00000001002bdff4 FMDBBlockSQLiteCallBackFunction
2  MyApp                          0x00000001002bdb1c FMDBBlockSQLiteCallBackFunction
3  MyApp                          0x00000001002b66b4 FMDBBlockSQLiteCallBackFunction
4  MyApp                          0x00000001002980fc FMDBBlockSQLiteCallBackFunction
5  MyApp                          0x000000010029f20c FMDBBlockSQLiteCallBackFunction
6  CFNetwork                      0x00000001851475a4 __49-[__NSCFLocalSessionTask _task_onqueue_didFinish]_block_invoke + 300
7  Foundation                     0x00000001866bf1c4 __NSBLOCKOPERATION_IS_CALLING_OUT_TO_A_BLOCK__ + 16
8  Foundation                     0x0000000186610604 -[NSBlockOperation main] + 96
9  Foundation                     0x00000001866001cc -[__NSOperationInternal _start:] + 636
10 Foundation                     0x00000001866c1f28 __NSOQSchedule_f + 228
11 libdispatch.dylib              0x0000000197655954 _dispatch_client_callout + 16
12 libdispatch.dylib              0x00000001976600a4 _dispatch_queue_drain + 1448
13 libdispatch.dylib              0x0000000197658a5c _dispatch_queue_invoke + 132
14 libdispatch.dylib              0x0000000197662318 _dispatch_root_queue_drain + 720
15 libdispatch.dylib              0x0000000197663c4c _dispatch_worker_thread3 + 108
16 libsystem_pthread.dylib        0x000000019783522c _pthread_wqthread + 816

Однако, прочитав код FMDB, он выглядит так: FMDBBlockSQLiteCallBackFunction вызывается только как обратный вызов для SQLite функций, созданных с использованием метода FMDatabase makeFunctionNamed:maximumArguments:withBlock:, который мы вообще не используем.

Любые идеи, которые могут вызывать такие сбои?

  • 0
    Произошло ли это после обновления приложения или после того, как что-то изменилось или просто неожиданно?
  • 0
    Нет, это происходило время от времени с момента запуска. Мы не смогли воспроизвести на месте, и на данный момент есть только отчеты о сбоях.
Показать ещё 9 комментариев
Теги:
fmdb

1 ответ

1

didFinish делает вид, что у вас может быть состояние гонки на этой строке:

6  CFNetwork                      0x00000001851475a4 __49-[__NSCFLocalSessionTask _task_onqueue_didFinish]_block_invoke + 300

Попробуйте подражать медленному оборудованию, чтобы воспроизвести состояние конечных пользователей.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню