Class ThreadedStreamConsumer
- java.lang.Object
-
- org.apache.maven.plugin.surefire.booterclient.output.ThreadedStreamConsumer
-
- All Implemented Interfaces:
java.io.Closeable,java.lang.AutoCloseable,EventHandler<Event>
public final class ThreadedStreamConsumer extends java.lang.Object implements EventHandler<Event>, java.io.Closeable
Knows how to reconstruct *all* the state transmitted over Channel by the forked process.
After applying the performance improvements withThreadedStreamConsumer.QueueSynchronizerthe throughput becomes 6.33 mega messages per second (158 nano seconds per message, 5 million messages within 0.79 seconds - see the test ThreadedStreamConsumerTest) on CPU i5 Dual Core 2.6 GHz and Oracle JDK 11.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description private static classThreadedStreamConsumer.FinalEvent(package private) classThreadedStreamConsumer.Pumper(package private) static classThreadedStreamConsumer.QueueSynchronizer<T>This synchronization helper mostly avoids the locks.
-
Field Summary
Fields Modifier and Type Field Description private java.lang.Threadconsumerprivate static EventEND_ITEMprivate java.util.concurrent.atomic.AtomicBooleanisAliveprivate ThreadedStreamConsumer.Pumperpumperprivate static intQUEUE_MAX_ITEMSprivate java.util.concurrent.atomic.AtomicBooleanstopprivate ThreadedStreamConsumer.QueueSynchronizer<Event>synchronizer
-
Constructor Summary
Constructors Constructor Description ThreadedStreamConsumer(EventHandler<Event> target)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclose()voidhandleEvent(Event event)private static booleanshouldStopQueueing(Event item)Compared item withEND_ITEMby identity.
-
-
-
Field Detail
-
QUEUE_MAX_ITEMS
private static final int QUEUE_MAX_ITEMS
- See Also:
- Constant Field Values
-
END_ITEM
private static final Event END_ITEM
-
synchronizer
private final ThreadedStreamConsumer.QueueSynchronizer<Event> synchronizer
-
stop
private final java.util.concurrent.atomic.AtomicBoolean stop
-
isAlive
private final java.util.concurrent.atomic.AtomicBoolean isAlive
-
consumer
private final java.lang.Thread consumer
-
pumper
private final ThreadedStreamConsumer.Pumper pumper
-
-
Constructor Detail
-
ThreadedStreamConsumer
public ThreadedStreamConsumer(EventHandler<Event> target)
-
-
Method Detail
-
handleEvent
public void handleEvent(@Nonnull Event event)- Specified by:
handleEventin interfaceEventHandler<Event>
-
close
public void close() throws java.io.IOException- Specified by:
closein interfacejava.lang.AutoCloseable- Specified by:
closein interfacejava.io.Closeable- Throws:
java.io.IOException
-
-