致命信号6 (SIGABRT) (code=-6) WebView

3
所以我有一个Webview和一个菜单。当我打开时,它工作正常。我设置了如果Webview进度不为0或不为100(加载页面时),Webview重新加载菜单项不可见(因此您看不到),停止菜单项可见。如果Webview加载了页面(因此进度为100)或无法加载页面(进度为0),则重新加载菜单项将变为可见,而停止菜单项将变为不可见。我说过,这很好用......直到我退出应用程序。(我没有从系统历史记录中清除)。

我重新打开了应用程序。崩溃!为什么?如果我从系统历史记录中删除该应用程序,则不会崩溃。我销毁了活动(在代码中),但它不起作用。

 // ...
 @Override
 public void onProgressChanged(WebView view, int progress) {
     progressBarLoad.setProgress(progress);
     int prInt = progressBarLoad.getProgress();
     if (prInt > 0 && prInt < 100) {
         menuMain.findItem(R.id.MenuExit).setVisible(true);
         menuMain.findItem(R.id.MenuReload).setVisible(false);
         }
     if (prInt == 100 || prInt == 0) {
         menuMain.findItem(R.id.MenuExit).setVisible(false);
         menuMain.findItem(R.id.MenuReload).setVisible(true);
         }
     }
 //...

OnKeyDown:

 @Override
    public boolean onKeyDown(int keyCode, @NonNull KeyEvent event) {
        if ((keyCode == KeyEvent.KEYCODE_BACK) && !webViewMain.canGoBack()) {
            if (booleanOnKeyDown) {
                new AlertDialog.Builder(this)
                        .setTitle(getString(R.string.SureExitTitle))
                        .setPositiveButton(getString(R.string.Yes), new DialogInterface.OnClickListener() {
                            public void onClick(DialogInterface dialog, int id) {
                                finish();
                                onDestroy();
                            }
                        })
                        .setNegativeButton(getString(R.string.No), new DialogInterface.OnClickListener() {
                            public void onClick(DialogInterface dialog, int id) {
                                dialog.cancel();
                            }
                        }).show();
            }
        }
        return super.onKeyDown(keyCode, event);
    }

日志:

10-26 12:41:15.867  14008-14008/com.zokni1996.android_forum W/System.err﹕ java.lang.NullPointerException
10-26 12:41:15.867  14008-14008/com.zokni1996.android_forum W/System.err﹕ at com.zokni1996.android_forum.Main.Main$6.onProgressChanged(Main.java:451)
10-26 12:41:15.867  14008-14008/com.zokni1996.android_forum W/System.err﹕ at com.android.webview.chromium.WebViewContentsClientAdapter.onProgressChanged(WebViewContentsClientAdapter.java:271)

请避免使用表情符号和“废话”。保持专业。 - Willi Mentzel
好的,抱歉,我会编辑的 :S (还有抱歉我的英语不好) - Zoltan Szilagyi
1个回答

1

我解决了这个问题(是的,这是一个非常非常糟糕的解决方案)。问题出在空指针异常上。我使用了try-catch。

// ...
@Override
public void onProgressChanged(WebView view, int progress) {
    progressBarLoad.setProgress(progress);
    if (progressBarLoad.getProgress() > 0 && progressBarLoad.getProgress() < 100) {
        try {
            menuMain.findItem(R.id.MenuExit).setVisible(true);
            menuMain.findItem(R.id.MenuReload).setVisible(false);
        } catch (Exception e) {
            Log.i("Menu failed reload or stop ", "" + e);
        }
    } else {
        try {
            menuMain.findItem(R.id.MenuExit).setVisible(false);
            menuMain.findItem(R.id.MenuReload).setVisible(true);
        } catch (Exception e) {
            Log.i("Menu failed reload or stop", "" + e);
        }
    }
}
//...

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接