在我的一个市场应用程序中,我不时看到一些来自野外的报告,并且无法确定它们被抛出的原因。我没有做任何我认为在我的应用程序中不寻常的事情。有没有人有任何想法?
java.lang.RuntimeException: Failed to unregister input channel. status=-22
at android.view.InputQueue.nativeUnregisterInputChannel(Native Method)
at android.view.InputQueue.unregisterInputChannel(InputQueue.java:119)
at android.view.ViewRootImpl.dispatchDetachedFromWindow(ViewRootImpl.java:2471)
at android.view.ViewRootImpl.doDie(ViewRootImpl.java:4030)
at android.view.ViewRootImpl.handleMessage(ViewRootImpl.java:2790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4517)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:993)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:760)
at dalvik.system.NativeStart.main(Native Method)
我看到很多“无法注册输入通道”的点击,但没有看到unregister,因此这个问题的原因。
我尝试搜索,但只从 AOSP 树中找到了这个作为异常来源:
from: aosp-frameworks-base / core / jni / android_view_InputQueue.cpp
static void android_view_InputQueue_nativeUnregisterInputChannel(JNIEnv* env, jclass clazz,
jobject inputChannelObj) {
status_t status = gNativeInputQueue.unregisterInputChannel(env, inputChannelObj);
if (status) {
String8 message;
message.appendFormat("Failed to unregister input channel. status=%d", status); <-- POSSIBLY THROWING THIS EXCEPTION
jniThrowRuntimeException(env, message.string());
}
}