【问题标题】:Android RuntimeException outside app code应用程序代码外的 Android RuntimeException
【发布时间】:2020-11-10 17:35:13
【问题描述】:

我遇到了一个奇怪的问题,该问题仅存在于特定设备上(或者至少在我测试我的应用的其他大约 10 台设备中不存在)。

有时,当应用程序应该显示一个进度对话框,然后是一个包含消息的 Toast 时,它反而会崩溃;在 Play Console 上查看,我看到了这个堆栈跟踪:

java.lang.RuntimeException: 
  at android.view.InputChannel.nativeReadFromParcel (Native Method)
  at android.view.InputChannel.readFromParcel (InputChannel.java:148)
  at android.view.IWindowSession$Stub$Proxy.addToDisplay (IWindowSession.java:796)
  at android.view.ViewRootImpl.setView (ViewRootImpl.java:750)
  at android.view.WindowManagerGlobal.addView (WindowManagerGlobal.java:298)
  at android.view.WindowManagerImpl.addView (WindowManagerImpl.java:91)
  at android.widget.Toast$TN.handleShow (Toast.java:732)
  at android.widget.Toast$TN$1.run (Toast.java:631)
  at android.os.Handler.handleCallback (Handler.java:739)
  at android.os.Handler.dispatchMessage (Handler.java:95)
  at android.os.Looper.loop (Looper.java:145)
  at android.app.ActivityThread.main (ActivityThread.java:6939)
  at java.lang.reflect.Method.invoke (Native Method)
  at java.lang.reflect.Method.invoke (Method.java:372)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run (ZygoteInit.java:1404)
  at com.android.internal.os.ZygoteInit.main (ZygoteInit.java:1199)

进度条和 Toast 应该大约每 5 秒显示一次。

如您所见,一切都发生在 Android 内部(没有参考我的实际代码),但我相信以下是涉及的代码片段。

这是显示进度条的地方:

public abstract class FragmentNetworkingBenderAsyncTask<I, O> extends BenderAsyncTask<I, O> {

    @SuppressLint("StaticFieldLeak")
    private final Fragment fragment;
    private AlertDialog waitDialog;

    public FragmentNetworkingBenderAsyncTask(final Fragment fragment) {
        this.fragment = fragment;
    }

    @Override
    protected final void onPreExecute() {
        super.onPreExecute();
        if (fragment.isAdded()) {
            waitDialog = new SpotsDialog.Builder().setContext(fragment.getActivity()).build();           waitDialog.setMessage(MainActivity.commonContext.getString(R.string.Wait));
            waitDialog.show();
            innerOnPreExecute(); //abstract method
        } else {
            this.cancel(true);
        }
    }

    [...]

    @Override
    protected final void onPostExecute(final BenderAsyncTaskResult<O> result) {
        super.onPostExecute(result);
        if (fragment.isAdded()) {
            if (result.isSuccess()) {
                innerOnSuccessfulPostExecute(result); //abstract
            } else {
                innerOnUnsuccessfulPostExecute(result); //abstract
            }
        }
        waitDialog.hide();
    }
}

虽然这是显示 Toast 的地方(该类继承自上一个 sn-p 中的类):

@SuppressLint("StaticFieldLeak")
private class ServerOrdersUploader extends FragmentNetworkingBenderAsyncTask<Order, Empty> {
    ServerOrdersUploader(Fragment fragment) {
        super(fragment);
    }

    [...]

    @Override
    protected void innerOnSuccessfulPostExecute(BenderAsyncTaskResult<Empty> result) {
        Toast.makeText(MainActivity.commonContext, MainActivity.commonContext.getString(R.string.UpdateSuccess), Toast.LENGTH_SHORT).show();
        new ServerOrdersDownloader(TableFragment.this).execute(tableNumber); //ServerOrdersDownloader has a similar behaviour
    }

    [...]
}
    

(完整代码可用here

正如我所说,问题似乎只发生在特定设备上(带有 Android 5.1 的三星 Galaxy Tab A6)。

会是什么?


编辑 31/07/2020:添加代码 sn-ps

【问题讨论】:

  • 有时 Android 平台本身存在错误,特别是在已被供应商修改的操作系统版本上(三星在这里肯定有资格)。也许您可以为这些设备使用 Toast.makeText() 以外的其他东西。
  • 您说“有时,当应用程序...”时,如果它甚至正确地显示了一次进度条,那么您重复该过程的方式可能有问题(使用计时器或处理程序)和与设备的资源交互或可能错误使用 API。无论哪种方式,如果您可以将日志放在代码的某些部分中以查看哪些被执行以及错误发生的时间点,这可能会有所帮助。
  • 有一个定时器可以让线程每隔几秒运行一次。没有进度条时没有问题(只有 Toast 有),在其他设备上也可以正常工作。 Here 是显示进度条的位置(第 25-29 行),而 here 是显示 toast 的位置(第 326 行)。
  • 如果你运行线程也许这是解决方案:stackoverflow.com/questions/17410734/…
  • 如果这是问题,它会出现在每台设备上,并且每次都会发生。此外,我已经这样做了。

标签: java android


【解决方案1】:

正如@Ben P. 所说,这可能是操作系统本身的错误, 我觉得问题的原因是进度条和 toast 有点重叠并且操作系统有问题来处理它。 尝试在另一个完成后执行一个

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多