我的应用程序由带有全屏WebView的片段组成。 当用户单击WebView中的链接时,将使用具有相同URL的新WebView打开新的片段。 在打开新的Fragment之前,我关闭软键盘,以防万一。 我很快打开新页面。 所有操作都在主线程上执行。
对于Crashlytics,问题仅适用于Android 10(所有Pixel系列设备和其他配备10的设备)。 在Android 10之前的设备上,一切正常。 我可以打开很多碎片。 但是在Android 10设备上,这种情况会导致致命异常(在2-3次快速尝试下随机打开新页面之后):
E/AndroidRuntime: FATAL EXCEPTION: pool-1-thread-1
Process: , PID: 12487
java.lang.RuntimeException: Probable deadlock detected due to WebView API being called on incorrect thread while the UI thread is blocked.
at Yp.a(PG:13)
at com.android.webview.chromium.WebViewChromium.onCheckIsTextEditor(PG:4)
at android.webkit.WebView.onCheckIsTextEditor(WebView.java:3035)
at android.view.inputmethod.InputMethodManager.checkFocusNoStartInput(InputMethodManager.java:1901)
at android.view.inputmethod.InputMethodManager.checkFocus(InputMethodManager.java:1863)
at android.view.inputmethod.InputMethodManager.hideSoftInputFromWindow(InputMethodManager.java:1506)
at android.view.inputmethod.InputMethodManager.hideSoftInputFromWindow(InputMethodManager.java:1475)
at .Utils.hideKeyboard(Utils.java:175)
at .openNewPage(Pager.java:210)
...
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:919)
Caused by: java.util.concurrent.TimeoutException
at java.util.concurrent.FutureTask.get(FutureTask.java:206)
at Yp.a(PG:11)
我试图使用Android系统WebView的所有可用版本(稳定版,测试版,开发者,金丝雀),但无济于事。
有人可以帮助我吗?
更新:
如果我注释隐藏软键盘的代码,则一切正常。