Interface ChannelGroupFuture
-
- All Superinterfaces:
java.lang.Iterable<ChannelFuture>
- All Known Implementing Classes:
DefaultChannelGroupFuture
public interface ChannelGroupFuture extends java.lang.Iterable<ChannelFuture>
The result of an asynchronousChannelGroupoperation.ChannelGroupFutureis composed ofChannelFutures which represent the outcome of the individual I/O operations that affect theChannels in theChannelGroup.All I/O operations in
ChannelGroupare asynchronous. It means any I/O calls will return immediately with no guarantee that the requested I/O operations have been completed at the end of the call. Instead, you will be returned with aChannelGroupFutureinstance which tells you when the requested I/O operations have succeeded, failed, or cancelled.Various methods are provided to let you check if the I/O operations has been completed, wait for the completion, and retrieve the result of the I/O operation. It also allows you to add more than one
ChannelGroupFutureListenerso you can get notified when the I/O operation have been completed.Prefer
It is recommended to preferaddListener(ChannelGroupFutureListener)toawait()addListener(ChannelGroupFutureListener)toawait()wherever possible to get notified when I/O operations are done and to do any follow-up tasks.addListener(ChannelGroupFutureListener)is non-blocking. It simply adds the specifiedChannelGroupFutureListenerto theChannelGroupFuture, and I/O thread will notify the listeners when the I/O operations associated with the future is done.ChannelGroupFutureListeneryields the best performance and resource utilization because it does not block at all, but it could be tricky to implement a sequential logic if you are not used to event-driven programming.By contrast,
await()is a blocking operation. Once called, the caller thread blocks until all I/O operations are done. It is easier to implement a sequential logic withawait(), but the caller thread blocks unnecessarily until all I/O operations are done and there's relatively expensive cost of inter-thread notification. Moreover, there's a chance of dead lock in a particular circumstance, which is described below.Do not call
await()insideChannelHandlerThe event handler methods in
ChannelHandleris often called by an I/O thread unless anExecutionHandleris in theChannelPipeline. Ifawait()is called by an event handler method, which is called by the I/O thread, the I/O operation it is waiting for might never be complete becauseawait()can block the I/O operation it is waiting for, which is a dead lock.// BAD - NEVER DO THIS
@Overridepublic void messageReceived(ChannelHandlerContextctx,MessageEvente) { if (e.getMessage() instanceof ShutdownMessage) {ChannelGroupallChannels = MyServer.getAllChannels();ChannelGroupFuturefuture = allChannels.close(); future.awaitUninterruptibly(); // Perform post-shutdown operation // ... } } // GOOD@Overridepublic void messageReceived(ChannelHandlerContext ctx, MessageEvent e) { if (e.getMessage() instanceof ShutdownMessage) {ChannelGroupallChannels = MyServer.getAllChannels();ChannelGroupFuturefuture = allChannels.close(); future.addListener(newChannelGroupFutureListener() { public void operationComplete(ChannelGroupFuturefuture) { // Perform post-closure operation // ... } }); } }In spite of the disadvantages mentioned above, there are certainly the cases where it is more convenient to call
await(). In such a case, please make sure you do not callawait()in an I/O thread. Otherwise,IllegalStateExceptionwill be raised to prevent a dead lock.
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description voidaddListener(ChannelGroupFutureListener listener)Adds the specified listener to this future.ChannelGroupFutureawait()Waits for this future to be completed.booleanawait(long timeoutMillis)Waits for this future to be completed within the specified time limit.booleanawait(long timeout, java.util.concurrent.TimeUnit unit)Waits for this future to be completed within the specified time limit.ChannelGroupFutureawaitUninterruptibly()Waits for this future to be completed without interruption.booleanawaitUninterruptibly(long timeoutMillis)Waits for this future to be completed within the specified time limit without interruption.booleanawaitUninterruptibly(long timeout, java.util.concurrent.TimeUnit unit)Waits for this future to be completed within the specified time limit without interruption.ChannelFuturefind(java.lang.Integer channelId)Returns theChannelFutureof the individual I/O operation which is associated with theChannelwhose ID matches the specified integer.ChannelFuturefind(Channel channel)Returns theChannelFutureof the individual I/O operation which is associated with the specifiedChannel.ChannelGroupgetGroup()Returns theChannelGroupwhich is associated with this future.booleanisCompleteFailure()Returnstrueif and only if all I/O operations associated with this future have failed without any success.booleanisCompleteSuccess()Returnstrueif and only if all I/O operations associated with this future were successful without any failure.booleanisDone()Returnstrueif and only if this future is complete, regardless of whether the operation was successful, failed, or canceled.booleanisPartialFailure()Returnstrueif and only if the I/O operations associated with this future have failed partially with some success.booleanisPartialSuccess()Returnstrueif and only if the I/O operations associated with this future were partially successful with some failure.java.util.Iterator<ChannelFuture>iterator()Returns theIteratorthat enumerates allChannelFutures which are associated with this future.voidremoveListener(ChannelGroupFutureListener listener)Removes the specified listener from this future.
-
-
-
Method Detail
-
getGroup
ChannelGroup getGroup()
Returns theChannelGroupwhich is associated with this future.
-
find
ChannelFuture find(java.lang.Integer channelId)
Returns theChannelFutureof the individual I/O operation which is associated with theChannelwhose ID matches the specified integer.- Returns:
- the matching
ChannelFutureif found.nullotherwise.
-
find
ChannelFuture find(Channel channel)
Returns theChannelFutureof the individual I/O operation which is associated with the specifiedChannel.- Returns:
- the matching
ChannelFutureif found.nullotherwise.
-
isDone
boolean isDone()
Returnstrueif and only if this future is complete, regardless of whether the operation was successful, failed, or canceled.
-
isCompleteSuccess
boolean isCompleteSuccess()
Returnstrueif and only if all I/O operations associated with this future were successful without any failure.
-
isPartialSuccess
boolean isPartialSuccess()
Returnstrueif and only if the I/O operations associated with this future were partially successful with some failure.
-
isCompleteFailure
boolean isCompleteFailure()
Returnstrueif and only if all I/O operations associated with this future have failed without any success.
-
isPartialFailure
boolean isPartialFailure()
Returnstrueif and only if the I/O operations associated with this future have failed partially with some success.
-
addListener
void addListener(ChannelGroupFutureListener listener)
Adds the specified listener to this future. The specified listener is notified when this future is done. If this future is already completed, the specified listener is notified immediately.
-
removeListener
void removeListener(ChannelGroupFutureListener listener)
Removes the specified listener from this future. The specified listener is no longer notified when this future is done. If this future is already completed, this method has no effect and returns silently.
-
await
ChannelGroupFuture await() throws java.lang.InterruptedException
Waits for this future to be completed.- Throws:
java.lang.InterruptedException- if the current thread was interrupted
-
awaitUninterruptibly
ChannelGroupFuture awaitUninterruptibly()
Waits for this future to be completed without interruption. This method catches anInterruptedExceptionand discards it silently.
-
await
boolean await(long timeout, java.util.concurrent.TimeUnit unit) throws java.lang.InterruptedExceptionWaits for this future to be completed within the specified time limit.- Returns:
trueif and only if the future was completed within the specified time limit- Throws:
java.lang.InterruptedException- if the current thread was interrupted
-
await
boolean await(long timeoutMillis) throws java.lang.InterruptedExceptionWaits for this future to be completed within the specified time limit.- Returns:
trueif and only if the future was completed within the specified time limit- Throws:
java.lang.InterruptedException- if the current thread was interrupted
-
awaitUninterruptibly
boolean awaitUninterruptibly(long timeout, java.util.concurrent.TimeUnit unit)Waits for this future to be completed within the specified time limit without interruption. This method catches anInterruptedExceptionand discards it silently.- Returns:
trueif and only if the future was completed within the specified time limit
-
awaitUninterruptibly
boolean awaitUninterruptibly(long timeoutMillis)
Waits for this future to be completed within the specified time limit without interruption. This method catches anInterruptedExceptionand discards it silently.- Returns:
trueif and only if the future was completed within the specified time limit
-
iterator
java.util.Iterator<ChannelFuture> iterator()
Returns theIteratorthat enumerates allChannelFutures which are associated with this future. Please note that the returnedIteratoris is unmodifiable, which means aChannelFuturecannot be removed from this future.- Specified by:
iteratorin interfacejava.lang.Iterable<ChannelFuture>
-
-