Это действительно зависит от того, что вы хотите с ним сделать, но вы можете сделать что-то столь же простое, как использование методов ожидания / уведомления, или вы можете использовать структуры из пакета java.util.concurrency. Последний лично будет моим выбором. Вы можете легко настроить BlockingQueue, чтобы производители могли перетаскивать объекты событий, а потребители - блокировать удаление событий.
// somewhere out there
public enum Events {
TERMINATE, DO_SOMETHING, BAKE_SOMETHING
}
// inside consumer
Events e;
while( (e = queue.take()) != TERMINATE ) {
switch(e) {
case DO_SOMETHING:
// blah blah
}
}
// somewhere else in another thread
Events e = BAKE_SOMETHING;
if( queue.offer(e) )
// the queue gladly accepted our BAKE_SOMETHING event!
else
// oops! we could block with put() if we want...