尝试使用crashlytics实现两个崩溃处理程序(如Crashlytics Android SDK - custom UncaughtExceptionHandler中所述),我无法在IntificationizationCalback中使用-在Kotlin中。有人有同样的问题吗?我的代码有问题吗? (为澄清起见,不会调用成功方法或失败方法,因此也不会执行新的UncaughtException处理程序)
val core = CrashlyticsCore.Builder()
.build()
Fabric.with(
Fabric.Builder(contextProvider.invoke()).kits(
Crashlytics.Builder()
.core(core)
.build()
).initializationCallback(object : InitializationCallback<Fabric> {
override fun success(fabric: Fabric) {
var mDefaultUEH = Thread.getDefaultUncaughtExceptionHandler()
Thread.setDefaultUncaughtExceptionHandler { t, e ->
Log.e("CrashLogger","Excpetion",e)
mDefaultUEH.uncaughtException(t, e)
}
}
override fun failure(e: Exception) {
Log.e("CrashLogger", "Error during initialization ", e)
}
}
).build()
)
答案 0 :(得分:0)
在我的应用程序类中尝试了几乎相同的代码,但它对我有用,调用了success()。
class MyApplication: MultiDexApplication() {
override fun onCreate() {
super.onCreate()
val core = CrashlyticsCore.Builder()
.build()
Fabric.with(
Fabric.Builder(this)
.kits(Crashlytics.Builder().core(core).build())
.initializationCallback(object: InitializationCallback<Fabric> {
override fun success(p0: Fabric?) {
Timber.d("InitializationCallback success")
}
override fun failure(p0: Exception?) {
Timber.d("InitializationCallback failure")
}
})
.build()
)
...
}
...
}
检查这些
io.fabric.ApiKey
中检查AndroidManifest.xml
contextProvider.invoke()
是否返回适当的上下文android.app.Application
作为上下文,看看它是否有效