2
 private fun setupGeckoView() {
        val runtime = GeckoRuntime.create(this) // crashes on this line
        geckoSession.open(runtime)
        geckoView.setSession(geckoSession)
        val url = String(Base64.decode(MYURL, Base64.DEFAULT))
        geckoSession.loadUri(url)
        geckoSession.progressDelegate = createProgressDelegate()
        geckoSession.settings.allowJavascript = true
    }

我在 onCreat() 中调用 setUpGeckoView 方法,但是当我单击返回并重新打开应用程序时,应用程序崩溃并出现 IllegalStateException 说“无法初始化 GeckoRuntime。它第一次工作只有在我单击返回然后再次打开应用程序时才会崩溃”

日志如下

 Process: arholding.kargoshop.mk, PID: 16444
    java.lang.RuntimeException: Unable to start activity ComponentInfo{arholding.kargoshop.mk/arholding.kargoshop.mk.SeckoActivity}: java.lang.IllegalStateException: Failed to initialize GeckoRuntime
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3447)
        at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:3594)
        at android.app.servertransaction.LaunchActivityItem.execute(LaunchActivityItem.java:83)
        at android.app.servertransaction.TransactionExecutor.executeCallbacks(TransactionExecutor.java:135)
        at android.app.servertransaction.TransactionExecutor.execute(TransactionExecutor.java:95)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2146)
        at android.os.Handler.dispatchMessage(Handler.java:107)
        at android.os.Looper.loop(Looper.java:237)
        at android.app.ActivityThread.main(ActivityThread.java:7762)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:493)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1047)
     Caused by: java.lang.IllegalStateException: Failed to initialize GeckoRuntime
        at org.mozilla.geckoview.GeckoRuntime.create(GeckoRuntime.java:458)
        at org.mozilla.geckoview.GeckoRuntime.create(GeckoRuntime.java:333)
        at arholding.kargoshop.mk.SeckoActivity.setupGeckoView(SeckoActivity.kt:23)
        at arholding.kargoshop.mk.SeckoActivity.onCreate(SeckoActivity.kt:19)
        at android.app.Activity.performCreate(Activity.java:7981)
        at android.app.Activity.performCreate(Activity.java:7970)
        at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1307)
        at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:3422)
4

1 回答 1

6

如果已经有一个活动的 Gecko 实例正在运行,则会引发此异常。有很多方法可以解决这个问题。

解决方案 1:获取给定上下文的默认运行时。

更改您的代码

val runtime = GeckoRuntime.create(this)

val runtime = GeckoRuntime.getDefault(this)

解决方案2:通过完成活动退出应用程序时终止进程,将此代码添加到您的活动中。

override fun onDestroy() {
    Process.killProcess(Process.myPid())
    super.onDestroy()
}

解决方案 3:仅在没有活动实例运行时才创建新实例

private fun setupGeckoView() {
    if (geckoRuntime == null) {
        geckoRuntime = GeckoRuntime.create(this)
    }

    geckoSession.open(geckoRuntime!!)
    geckoView.setSession(geckoSession)
    val url = String(Base64.decode(MYURL, Base64.DEFAULT))
    geckoSession.loadUri(url)
    geckoSession.progressDelegate = createProgressDelegate()
    geckoSession.settings.allowJavascript = true
}

companion object {
    var geckoRuntime: GeckoRuntime? = null
}
于 2019-12-17T06:51:33.377 回答