我有一个自定义键盘应用程序,当我按下后退按钮退出时,我得到这个LogCat输出大约1/4的时间:
12-19 13:18:13.908: W/InputMethodManager(361): IME died: com.mypackage/.MyActivity dropping: KeyEvent{action=1 code=4 repeat=0 meta=0 scancode=158 mFlags=72}
12-19 13:18:13.908: W/InputMethodManager(361): android.os.DeadObjectException
12-19 13:18:13.908: W/InputMethodManager(361): at android.os.BinderProxy.transact(Native Method)
12-19 13:18:13.908: W/InputMethodManager(361): at com.android.internal.view.IInputMethodSession$Stub$Proxy.dispatchKeyEvent(IInputMethodSession.java:277)
12-19 13:18:13.908: W/InputMethodManager(361): at android.view.inputmethod.InputMethodManager.dispatchKeyEvent(InputMethodManager.java:1344)
12-19 13:18:13.908: W/InputMethodManager(361): at android.view.ViewRoot.deliverKeyEvent(ViewRoot.java:2426)
12-19 13:18:13.908: W/InputMethodManager(361): at android.view.ViewRoot.handleMessage(ViewRoot.java:1741)
12-19 13:18:13.908: W/InputMethodManager(361): at android.os.Handler.dispatchMessage(Handler.java:99)
12-19 13:18:13.908: W/InputMethodManager(361): at android.os.Looper.loop(Looper.java:123)
12-19 13:18:13.908: W/InputMethodManager(361): at android.app.ActivityThread.main(ActivityThread.java:4627)
12-19 13:18:13.908: W/InputMethodManager(361): at java.lang.reflect.Method.invokeNative(Native Method)
12-19 13:18:13.908: W/InputMethodManager(361): at java.lang.reflect.Method.invoke(Method.java:521)
12-19 13:18:13.908: W/InputMethodManager(361): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
12-19 13:18:13.908: W/InputMethodManager(361): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
12-19 13:18:13.908: W/InputMethodManager(361): at dalvik.system.NativeStart.main(Native Method)
有人遇到过这种情况吗?
这是我重写后退按钮时的代码
if(mInputView.getVisibility() == View.VISIBLE){
if(isInputViewShown()){
if(output != null){
if(getCurrentInputConnection() != null){
getCurrentInputConnection().deleteSurroundingText(1000, 1000);
getCurrentInputConnection().commitText(output.getText(), output.length());
}
output.setText("");
}
requestHideSelf(0);
return true;
}else return false;
谷歌搜索"android.os. "DeadobjectException IME"产生这个:http://osdir.com/ml/Android-Developers/2010-10/msg04248.html
似乎当UI在IME被杀死之前没有机会处理所有关键事件时抛出异常。这就解释了第一行:
12-19 13:18:13.908: W/InputMethodManager(361): IME died: com.mypackage/.MyActivity dropping: KeyEvent{action=1 code=4 repeat=0 meta=0 scancode=158 mFlags=72}
这个消息没什么大不了的,它是在处理所有关键事件之前杀死IME的结果。
看起来您在取消键盘和调度由按下后退按钮生成的键事件之间得到了一个竞争条件。DeadObjectException
表示尽管对象(这里是KeyEvent
)仍在使用,但它的宿主进程(IME)已经死亡。这将使对象无效并抛出异常。
您可以在KeyEvent
参数中看到这一点。键码为4,即KeyEvent.KEYCODE_BACK
的值。
不同的手机在这方面可能表现不同(这个未回答的问题是相似的)。我想这个异常可以忽略。