Package org.infinispan.executors
Class SemaphoreCompletionService<T>
java.lang.Object
org.infinispan.executors.SemaphoreCompletionService<T>
- All Implemented Interfaces:
- CompletionService<T>
Executes tasks in the given executor, but never has more than 
maxConcurrentTasks tasks running at the same time.- Since:
- 7.2
- Author:
- Dan Berindei
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionbackgroundTaskFinished(Callable<T> cleanupTask) Signal that a task that calledcontinueTaskInBackground()has finished and optionally execute another task on the just-freed thread.voidWhen stopping, cancel any queued tasks.voidCalled from a task to remove the permit that would otherwise be freed when the task finishes running When the asynchronous part of the task finishes, it must callbackgroundTaskFinished(Callable)to make the permit available again.poll()take()
- 
Constructor Details- 
SemaphoreCompletionService
 
- 
- 
Method Details- 
drainCompletionQueue
- 
cancelQueuedTaskspublic void cancelQueuedTasks()When stopping, cancel any queued tasks.
- 
continueTaskInBackgroundpublic void continueTaskInBackground()Called from a task to remove the permit that would otherwise be freed when the task finishes running When the asynchronous part of the task finishes, it must callbackgroundTaskFinished(Callable)to make the permit available again.
- 
backgroundTaskFinishedSignal that a task that calledcontinueTaskInBackground()has finished and optionally execute another task on the just-freed thread.
- 
submit- Specified by:
- submitin interface- CompletionService<T>
 
- 
submit- Specified by:
- submitin interface- CompletionService<T>
 
- 
take- Specified by:
- takein interface- CompletionService<T>
- Throws:
- InterruptedException
 
- 
poll- Specified by:
- pollin interface- CompletionService<T>
 
- 
poll- Specified by:
- pollin interface- CompletionService<T>
- Throws:
- InterruptedException
 
 
-