java - 应用程序代码外的 Android RuntimeException
问题描述
我遇到了一个奇怪的问题,它只存在于特定设备上(或者至少在我测试我的应用程序的大约 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 的地方(该类继承自上一个片段中的类):
@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
}
[...]
}
(此处提供完整代码)
正如我所说,问题似乎只发生在特定设备上(带有 Android 5.1 的三星 Galaxy Tab A6)。
会是什么呢?
编辑 31/07/2020:添加代码片段
解决方案
正如@Ben P.所说,这可能是操作系统本身的一个错误,我觉得问题的原因是进度条和吐司有点重叠并且操作系统处理它有问题。尝试在另一个完成后执行一个
推荐阅读
- android - 在 PreferenceActivity 中加载不同的 XML 值集
- python - 关于离线绘图和更新 jupyter notebook 中的图表的困惑
- javafx - JavaFX:X 轴上的对数刻度
- jpa - 从 Java 10.0 NullPointer 开始搜索持久性 - JPA eclipselink 2.6.5
- python - 如何仅访问列表的特定元素
- c# - Xamarin 登录页面和 C#
- linux - 哪个Linux程序将失败的sshd登录尝试写入/var/log/btmp Centos 7
- php - Laravel 5.6 RESRful Webervice 更新和删除
- asp.net-core-mvc - 在控制器内调用 add-migration
- blockchain - 去中心化存储系统 Storj 是如何工作的?