Примечание. Символы отображаются в сбоях для нашей библиотеки C++. Проблема в том, что они не отображаются для системных библиотек, таких как libc, libart. , libbase и libandroid_runtime.
У нас есть несколько сложных сбоев, которые происходят исключительно во время выполнения Android и их трудно отладить без символов. В Firebase Crashlytics мы видим следующую трассировку стека:
Crashed: Thread : SIGABRT 0x0000000000000000
#00 pc 0x4e574 libc.so
#01 pc 0x4e540 libc.so
#02 pc 0x5677d8 libart.so
#03 pc 0x13ab0 libbase.so
#04 pc 0x13090 libbase.so
#05 pc 0x38cb6c libart.so
#06 pc 0x39f7d8 libart.so
#07 pc 0x1260e0 libandroid_runtime.so
#08 pc 0x124ef4 libandroid_runtime.so
#09 pc 0x124dc4 libandroid_runtime.so
#10 pc 0x115468 libandroid_runtime.so
Когда я вызываю сбой теста в нашей библиотеке C++ путем разыменования нулевого указателя, я вижу следующую обратную трассировку в моей локальной консоли Android Studio:
...snip...
#06 pc 00000000002d7644 /apex/com.android.art/lib64/libart.so (art_quick_generic_jni_trampoline+148) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
#07 pc 00000000002cdd64 /apex/com.android.art/lib64/libart.so (art_quick_invoke_stub+548) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
#08 pc 00000000002f23d0 /apex/com.android.art/lib64/libart.so (art::interpreter::ArtInterpreterToCompiledCodeBridge(art::Thread*, art::ArtMethod*, art::ShadowFrame*, unsigned short, art::JValue*)+312) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
#09 pc 00000000003839f4 /apex/com.android.art/lib64/libart.so (bool art::interpreter::DoCall(art::ArtMethod*, art::Thread*, art::ShadowFrame&, art::Instruction const*, unsigned short, art::JValue*)+800) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
#10 pc 00000000003813f4 /apex/com.android.art/lib64/libart.so (MterpInvokeVirtualRange+1368) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
#11 pc 00000000002c8714 /apex/com.android.art/lib64/libart.so (mterp_op_invoke_virtual_range+20) (BuildId: adb75d6f792faa24b1bc8cf512fb112c)
...snip...
Однако тот же краш в крашлитике выглядит так:
...snip...
#07 pc 0x222244 libart.so
#08 pc 0x218964 libart.so
#09 pc 0x284208 libart.so
#10 pc 0x3e34ac libart.so
#11 pc 0x800ba4 libart.so
...snip...
Как мы можем заставить Crashlytics включать информацию, которая явно содержится в аварийном дампе?
Некоторые примечания по настройке нашей сборки:
- Мы уже следили за https://firebase.google.com/docs/crashl ... dk-reports
- Gradle Project 1 строит встроенная библиотека, гарантирующая, что отладка включена и символы не удаляются.
- Gradle Project 2 собирает приложение и ссылки в библиотеке, а также сообщает Crashlytics о необходимости загрузки собственных символов.
nativeSymbolUploadEnabled true
unstrippedNativeLibsDir file("PATH/TO/UNSTRIPPED/DIRECTORY")
}
Подробнее здесь: https://stackoverflow.com/questions/727 ... ndroid-ndk