Das angegebene Sperr-Token für die Synchronisierung der Nachrichtenwarteschlange wurde nicht gesendet

Ich habe eine App die als Service gebunden ist. Ich sende Nachrichten an den Dienst, erhalte jedoch manchmal die folgende Fehlermeldung:

E / AndroidRuntime (28216): java.lang.IllegalStateException: Das angegebene Sperr-Token für die Synchronisierung der Nachrichtenwarteschlange wurde nicht bereitgestellt oder wurde bereits entfernt.

Manchmal erhalte ich stattdessen diesen Fehler:

android.util.AndroidRuntimeException: {what = 888 when = 0} Diese Nachricht wird bereits verwendet.

Manchmal friert die Benutzeroberfläche einfach ein. Ich kommuniziere vom Service zur Aktivität und umgekehrt durch Handler.

 public void init(IBinder service){
    playerService = new Messenger(service);
    setBound(true);
    try {
        Message msg = Message.obtain(null, PlayerService.MSG_REGISTER_CLIENT);
        msg.replyTo = messenger;
        playerService.send(msg);
        while(!messageQueue.isEmpty()){
            playerService.send(messageQueue.remove());
        }
    } catch (RemoteException e) {
        // In this case the service has crashed before we could even do anything with it
        Log.d(Player.TAG, "problem binding player messenger " + e.getMessage());
    }
}

Hier ist eine Methode, die beim zweiten Aufruf konsistent zum Einfrieren führt.

public void play(String url) {
    Message msg = Message.obtain(null, PlayerService.PLAY, 0, 0);
    msg.setData(getURLBundle(url));
    sendMessage(msg);
}

private void sendMessage(Message message){
    if(!isBound){
        Log.d(Player.TAG, "isnt bound, queueing message");
        messageQueue.add(message);
    }else {
        try {
            playerService.send(message);
        } catch (RemoteException e) {
            e.printStackTrace();
        }
    }
}

Ich bin neu in Threading, Messengers und Handlers, daher ist jede Hilfe dankbar, danke :)

Antworten auf die Frage(1)

Ihre Antwort auf die Frage