public abstract class MultithreadEventExecutorGroup extends AbstractEventExecutorGroup
EventExecutorGroup
implementations that handles their tasks with multiple threads at
the same time.Modifier | Constructor and Description |
---|---|
protected |
MultithreadEventExecutorGroup(int nThreads,
Executor executor,
EventExecutorChooserFactory chooserFactory,
Object... args)
Create a new instance.
|
protected |
MultithreadEventExecutorGroup(int nThreads,
Executor executor,
Object... args)
Create a new instance.
|
protected |
MultithreadEventExecutorGroup(int nThreads,
ThreadFactory threadFactory,
Object... args)
Create a new instance.
|
Modifier and Type | Method and Description |
---|---|
boolean |
awaitTermination(long timeout,
TimeUnit unit) |
int |
executorCount()
Return the number of
EventExecutor this implementation uses. |
boolean |
isShutdown() |
boolean |
isShuttingDown()
Returns
true if and only if all EventExecutor s managed by this EventExecutorGroup
are being shut down gracefully or was shut down. |
boolean |
isTerminated() |
Iterator<EventExecutor> |
iterator() |
protected abstract EventExecutor |
newChild(Executor executor,
Object... args)
Create a new EventExecutor which will later then accessible via the
next() method. |
protected ThreadFactory |
newDefaultThreadFactory() |
EventExecutor |
next()
Returns one of the
EventExecutor s managed by this EventExecutorGroup . |
void |
shutdown()
Deprecated.
|
Future<?> |
shutdownGracefully(long quietPeriod,
long timeout,
TimeUnit unit)
Signals this executor that the caller wants the executor to be shut down.
|
Future<?> |
terminationFuture()
Returns the
Future which is notified when all EventExecutor s managed by this
EventExecutorGroup have been terminated. |
execute, invokeAll, invokeAll, invokeAny, invokeAny, schedule, schedule, scheduleAtFixedRate, scheduleWithFixedDelay, shutdownGracefully, shutdownNow, submit, submit, submit
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
forEach, spliterator
protected MultithreadEventExecutorGroup(int nThreads, ThreadFactory threadFactory, Object... args)
nThreads
- the number of threads that will be used by this instance.threadFactory
- the ThreadFactory to use, or null
if the default should be used.args
- arguments which will passed to each newChild(Executor, Object...)
callprotected MultithreadEventExecutorGroup(int nThreads, Executor executor, Object... args)
nThreads
- the number of threads that will be used by this instance.executor
- the Executor to use, or null
if the default should be used.args
- arguments which will passed to each newChild(Executor, Object...)
callprotected MultithreadEventExecutorGroup(int nThreads, Executor executor, EventExecutorChooserFactory chooserFactory, Object... args)
nThreads
- the number of threads that will be used by this instance.executor
- the Executor to use, or null
if the default should be used.chooserFactory
- the EventExecutorChooserFactory
to use.args
- arguments which will passed to each newChild(Executor, Object...)
callprotected ThreadFactory newDefaultThreadFactory()
public EventExecutor next()
EventExecutorGroup
EventExecutor
s managed by this EventExecutorGroup
.public Iterator<EventExecutor> iterator()
public final int executorCount()
EventExecutor
this implementation uses. This number is the maps
1:1 to the threads it use.protected abstract EventExecutor newChild(Executor executor, Object... args) throws Exception
next()
method. This method will be
called for each thread that will serve this MultithreadEventExecutorGroup
.Exception
public Future<?> shutdownGracefully(long quietPeriod, long timeout, TimeUnit unit)
EventExecutorGroup
EventExecutorGroup.isShuttingDown()
starts to return true
, and the executor prepares to shut itself down.
Unlike EventExecutorGroup.shutdown()
, graceful shutdown ensures that no tasks are submitted for 'the quiet period'
(usually a couple seconds) before it shuts itself down. If a task is submitted during the quiet period,
it is guaranteed to be accepted and the quiet period will start over.quietPeriod
- the quiet period as described in the documentationtimeout
- the maximum amount of time to wait until the executor is EventExecutorGroup.shutdown()
regardless if a task was submitted during the quiet periodunit
- the unit of quietPeriod
and timeout
EventExecutorGroup.terminationFuture()
public Future<?> terminationFuture()
EventExecutorGroup
Future
which is notified when all EventExecutor
s managed by this
EventExecutorGroup
have been terminated.@Deprecated public void shutdown()
shutdown
in interface EventExecutorGroup
shutdown
in interface ExecutorService
shutdown
in class AbstractEventExecutorGroup
public boolean isShuttingDown()
EventExecutorGroup
true
if and only if all EventExecutor
s managed by this EventExecutorGroup
are being shut down gracefully or was shut down.public boolean isShutdown()
public boolean isTerminated()
public boolean awaitTermination(long timeout, TimeUnit unit) throws InterruptedException
InterruptedException
Copyright © 2008–2017 The Netty Project. All rights reserved.