【问题标题】:Android: Shutting down thread and Looper correctly?Android:正确关闭线程和 Looper?
【发布时间】:2014-04-19 01:43:08
【问题描述】:

我像这样关闭了我的线程: theSensor.getLooper().quit(); theSensor.quit();

我仍然收到以下错误。我需要做什么才能忽略其余消息?

03-14 00:42:12.237: W/MessageQueue(10027): Handler (android.os.Handler) {41d5e6d8} sending message to a Handler on a dead thread
03-14 00:42:12.237: W/MessageQueue(10027): java.lang.RuntimeException: Handler (android.os.Handler) {41d5e6d8} sending message to a Handler on a dead thread
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.MessageQueue.enqueueMessage(MessageQueue.java:294)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Handler.enqueueMessage(Handler.java:618)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Handler.sendMessageAtTime(Handler.java:587)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Handler.sendMessageDelayed(Handler.java:558)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Handler.sendMessage(Handler.java:495)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Message.sendToTarget(Message.java:360)
03-14 00:42:12.237: W/MessageQueue(10027):  at com.sj.framework.tiltsensor.TiltSensor.onSensorChanged(TiltSensor.java:158)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.hardware.SystemSensorManager$ListenerDelegate$1.handleMessage(SystemSensorManager.java:256)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.os.Looper.loop(Looper.java:137)
03-14 00:42:12.237: W/MessageQueue(10027):  at android.app.ActivityThread.main(ActivityThread.java:5306)
03-14 00:42:12.237: W/MessageQueue(10027):  at java.lang.reflect.Method.invokeNative(Native Method)
03-14 00:42:12.237: W/MessageQueue(10027):  at java.lang.reflect.Method.invoke(Method.java:511)
03-14 00:42:12.237: W/MessageQueue(10027):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1102)
03-14 00:42:12.237: W/MessageQueue(10027):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:869)
03-14 00:42:12.237: W/MessageQueue(10027):  at dalvik.system.NativeStart.main(Native Method)

【问题讨论】:

    标签: java android multithreading looper


    【解决方案1】:

    您尝试过quitSafely 方法吗? api 文档中的描述看起来像你什么。它将禁用 MessageQueue,以便 sendMessage 将返回 false 并尝试传递消息将不会成功。 quitSafely

    安全退出弯针。

    在处理完消息队列中所有剩余的消息后,立即终止 loop() 方法。但是,在循环终止之前,将不会传递具有未来到期时间的未决延迟消息。

    在要求 Looper 退出后,任何向队列发布消息的尝试都将失败。例如 sendMessage(Message) 方法会返回 false。

    【讨论】:

    • quitSafely api 在 SDK 18+ 上可用。有什么方法可以在较低版本中支持这一点?
    猜你喜欢
    • 2013-09-17
    • 2023-03-30
    • 1970-01-01
    • 2014-10-03
    • 1970-01-01
    • 2014-09-02
    • 2018-04-30
    • 2013-11-15
    • 1970-01-01
    相关资源
    最近更新 更多