0

我有一个自定义键盘应用程序,当我按下后退按钮退出它时,我得到这个 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;
4

2 回答 2

2

谷歌搜索“android.os.DeadobjectException IME”会产生这样的结果:http: //osdir.com/ml/Android-Developers/2010-10/msg04248.html

当在 IME 被杀死之前 UI 没有机会处理所有关键事件时,似乎引发了异常。这将解释第一行:

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 的结果。

于 2011-12-19T18:50:16.090 回答
1

看起来您在取消键盘和调度通过按后退按钮生成的 keyevent 之间遇到了竞争条件。这DeadObjectException意味着尽管对象(这里是KeyEvent)仍在使用中,但它的宿主进程(IME)已经死亡。这会使对象无效并引发异常。

您可以在KeyEvent参数中看到这一点。键码为 4,即 的值KeyEvent.KEYCODE_BACK

不同的手机在这里可能表现不同(这个未回答的问题是相似的)。我猜这个异常可以忽略。

于 2011-12-19T18:50:41.923 回答