Class ParallelFuture
java.lang.Object
com.tccc.kos.commons.util.concurrent.future.FutureWork
com.tccc.kos.commons.util.concurrent.future.ParallelFuture
- All Implemented Interfaces:
- Abortable,- Cancelable,- Terminable,- Runnable
Allows a collection of individual futures to be run in parallel, where the
 overall state of 
ParallelFuture reflects the result of the child
 futures. All child futures are executed in the scheduler thread pool to ensure
 clean decoupling from event threads that may be used to finalize the state of
 the future.
 Cancelling this future will cancel all running children.
The end state of this future is SUCCESS if all children are SUCCESS.
The end state in case of FAIL or ABORT can be set to achieve the desired outcome.
- Since:
- 1.0
- Version:
- 2022-05-05
- 
Field SummaryFieldsFields inherited from class com.tccc.kos.commons.util.concurrent.future.FutureWorkREASON_errStartCallbackFailed, REASON_errTimedOut
- 
Constructor SummaryConstructorsConstructorDescriptionParallelFuture(String name) Creates aParallelFutureto hold all child futures.
- 
Method SummaryModifier and TypeMethodDescriptionvoidadd(FutureWork future) Adds a future to the collection.voidFails the work with the specified reason.longWhen running in parallel, the estimated completion time is equal to the longest child task.booleanIf true, cancel all child futures if any individual child future aborts.booleanIf true, cancel all child futures if any individual child future fails.voidsetAbortState(FutureState state) Sets the end state to use for the parent future if any child future aborts.voidsetFailState(FutureState state) Sets the end state to use for the parent future if any child future fails.setRunnable(FutureRunnable runnable) Sets therunnableto be performed by the work.voidsetTerminatelOnFail(boolean enable) If true, cancel all child futures if any individual child future fails, otherwise ignore failed children and allow all other children to complete.voidsetTerminateOnAbort(boolean enable) If true, cancel all child futures if any individual child future aborts, otherwise ignore failed children and allow all other children to complete.voidsuccess()Marks the work "successful".Methods inherited from class com.tccc.kos.commons.util.concurrent.future.FutureWorkabort, abort, abort, append, cancel, cancel, cancel, cancelTimeout, disableAbortAbandoned, execute, extend, fail, fail, getAbortAbandonedTimeoutMs, getClientData, getData, getEndState, getEstimatedEndTimeMono, getId, getName, getNote, getProgress, getReason, getReasonData, getRemainingTimeMs, getRootFuture, getStartTimeMono, getTracker, interruptableSleep, interruptIfPending, isAbort, isCancel, isDone, isFail, isInterruptable, isInterrupted, isRunComplete, isRunStarted, isSuccess, isTerminate, prepend, remove, run, setAbortAbandonedTimeoutMs, setData, setEstimatedTimeMs, setInterruptable, setNote, setParent, setProgress, setRemainingTimeMs, setState, setState, setTimeout, setTimeout, setTimeout, sleep, successAfterDelay, toString, waitUntilFinished, whenFinished
- 
Field Details- 
REASON_errAbortedSibling- See Also:
 
- 
REASON_errFailedSibling- See Also:
 
 
- 
- 
Constructor Details- 
ParallelFutureCreates aParallelFutureto hold all child futures.- Parameters:
- name- the name (for diagnostic data)
 
 
- 
- 
Method Details- 
isTerminateOnFailpublic boolean isTerminateOnFail()If true, cancel all child futures if any individual child future fails.
- 
setTerminatelOnFailpublic void setTerminatelOnFail(boolean enable) If true, cancel all child futures if any individual child future fails, otherwise ignore failed children and allow all other children to complete.- Parameters:
- enable- true to cancel children if any child fails
 
- 
isTerminateOnAbortpublic boolean isTerminateOnAbort()If true, cancel all child futures if any individual child future aborts.
- 
setTerminateOnAbortpublic void setTerminateOnAbort(boolean enable) If true, cancel all child futures if any individual child future aborts, otherwise ignore failed children and allow all other children to complete.- Parameters:
- enable- true to cancel children if any child aborts
 
- 
setFailStateSets the end state to use for the parent future if any child future fails. By default the end state will beFAILbut it can be set toABORT. This does not impact whether the children continue to run, just what the final end state will be.- Parameters:
- state- either ABORT or FAIL
 
- 
setAbortStateSets the end state to use for the parent future if any child future aborts. By default the end state will beABORTbut it can be set toFAIL. This does not impact whether the children continue to run, just what the final end state will be.- Parameters:
- state- either abort or fail
 
- 
setRunnableDescription copied from class:FutureWorkSets therunnableto be performed by the work. Unlike Java futures, it is possible for this work to complete without changing the end state. For example, this work may simply kick off a hardware process and some other mechanism is used to determine when that hardware is done, and that will change the state.This runnablecan set the state, but callbacks won't be triggered until this function returns. This prevents race conditions between this code and any state event callbacks.If this runnable throws an exception, then the state is set to "aborted". - Overrides:
- setRunnablein class- FutureWork
- Parameters:
- runnable- the code to run as part of the work
 
- 
failDescription copied from class:FutureWorkFails the work with the specified reason.- Overrides:
- failin class- FutureWork
- Parameters:
- reason- the fail reason
 
- 
successpublic void success()Description copied from class:FutureWorkMarks the work "successful".- Overrides:
- successin class- FutureWork
 
- 
addAdds a future to the collection. Futures can only be added before processing starts.- Parameters:
- future- the work to add to the sequence
 
- 
getEstimatedTimeMspublic long getEstimatedTimeMs()When running in parallel, the estimated completion time is equal to the longest child task.- Overrides:
- getEstimatedTimeMsin class- FutureWork
- Returns:
- the estimated time of the operation
 
 
-