Class ParallelExecutorBase<T>
java.lang.Object
org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E>
org.eclipse.rdf4j.common.iteration.LookAheadIteration<T>
org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBase<T>
- Type Parameters:
- T-
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- Iterator<T>,- CloseableIteration<T>,- ParallelExecutor<T>
- Direct Known Subclasses:
- JoinExecutorBase,- UnionExecutorBase
public abstract class ParallelExecutorBase<T>
extends LookAheadIteration<T>
implements ParallelExecutor<T>
Base class for common parallel executors such as 
JoinExecutorBase and UnionExecutorBase.- Author:
- Andreas Schwarte
- See Also:
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected Threadprotected final longprotected booleanprotected static final org.slf4j.Loggerprotected static final AtomicLongprotected final QueryInfoprotected CloseableIteration<T>protected FedXQueueCursor<T>protected final FederationEvalStrategy
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionvoidaddResult(CloseableIteration<T> res) Handle the result appropriately, e.g.protected voidChecks whether the query execution has run into a timeout.voiddone()Inform the controlling instance that some job is done from a different thread.protected Stringprotected StringgetId()Gets the next element.Return the query info of the associated queryvoidCalled byAbstractCloseableIteration.close()when it is called for the first time.booleanReturn true if this executor is finished or abortedprotected abstract voidPerform the parallel execution.final voidrun()voidToss some exception to the controlling instancetoString()Methods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, removeMethods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosedMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface org.eclipse.rdf4j.common.iteration.CloseableIterationstreamMethods inherited from interface java.util.IteratorforEachRemaining
- 
Field Details- 
logprotected static final org.slf4j.Logger log
- 
NEXT_EXECUTOR_ID
- 
strategy
- 
executorIdprotected final long executorId
- 
queryInfo
- 
evaluationThread
- 
rightQueue
- 
rightIter
- 
finishedprotected volatile boolean finished
 
- 
- 
Constructor Details- 
ParallelExecutorBase- Throws:
- QueryEvaluationException
 
 
- 
- 
Method Details- 
runpublic final void run()
- 
performExecutionPerform the parallel execution.Note that this method must block until the execution is completed. - Throws:
- Exception
 
- 
addResultDescription copied from interface:ParallelExecutorHandle the result appropriately, e.g. add it to the result iteration. Take care for synchronization in a multithreaded environment- Specified by:
- addResultin interface- ParallelExecutor<T>
 
- 
donepublic void done()Description copied from interface:ParallelExecutorInform the controlling instance that some job is done from a different thread. In most cases this is a no-op.- Specified by:
- donein interface- ParallelExecutor<T>
 
- 
tossDescription copied from interface:ParallelExecutorToss some exception to the controlling instance- Specified by:
- tossin interface- ParallelExecutor<T>
 
- 
getNextElementDescription copied from class:LookAheadIterationGets the next element. Subclasses should implement this method so that it returns the next element.- Specified by:
- getNextElementin class- LookAheadIteration<T>
- Returns:
- The next element, or null if no more elements are available.
- Throws:
- QueryEvaluationException
 
- 
checkTimeoutChecks whether the query execution has run into a timeout. If so, aQueryInterruptedExceptionis thrown.- Throws:
- QueryInterruptedException
 
- 
handleCloseDescription copied from class:AbstractCloseableIterationCalled byAbstractCloseableIteration.close()when it is called for the first time. This method is only called once on each iteration. By default, this method does nothing.- Specified by:
- handleClosein class- AbstractCloseableIteration<T>
- Throws:
- QueryEvaluationException
 
- 
isFinishedpublic boolean isFinished()Return true if this executor is finished or aborted- Specified by:
- isFinishedin interface- ParallelExecutor<T>
- Returns:
- whether the executor is finished
 
- 
getQueryInfoDescription copied from interface:ParallelExecutorReturn the query info of the associated query- Specified by:
- getQueryInfoin interface- ParallelExecutor<T>
- Returns:
- the query info
 
- 
getId- Returns:
- a unique identifier of this execution
 
- 
getDisplayId
- 
getExecutorType- Returns:
- the executor type, e.g. "Join". Default "Executor"
 
- 
toString
 
-