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 :)