Good day

Does Akka provide functionality to empty an actor's mailbox? I need all 
message processing in an actor to immediately stop after receiving a 
specific message. I have tried something like this:

@Override
public void onReceive(Object msg) throws Throwable {
if (msg instanceof SomeMessage){
if (!running){
return;
}
// Process message
} else if (msg instanceof SomeOtherMessage){
if (!running){
return;
}
// Process message
} else if (msg instanceof Stop){
running = false;
} else if (msg instanceof Start){
running = true;
} else {
unhandled(msg);
}
}

This approach works for the most part, but if there are too many messages 
queued, the actor's mailbox is not empty by the time the "Start" message is 
received, and this causes issues with data structures etc. held by the 
actor.

Thanks in advance.

Marc

-- 
>>>>>>>>>>      Read the docs: http://akka.io/docs/
>>>>>>>>>>      Check the FAQ: 
>>>>>>>>>> http://doc.akka.io/docs/akka/current/additional/faq.html
>>>>>>>>>>      Search the archives: https://groups.google.com/group/akka-user
--- 
You received this message because you are subscribed to the Google Groups "Akka 
User List" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to akka-user+unsubscr...@googlegroups.com.
To post to this group, send email to akka-user@googlegroups.com.
Visit this group at https://groups.google.com/group/akka-user.
For more options, visit https://groups.google.com/d/optout.

Reply via email to