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 asJoinExecutorBaseandUnionExecutorBase.- Author:
- Andreas Schwarte
- See Also:
- JoinExecutorBase,- UnionExecutorBase
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected ThreadevaluationThreadprotected longexecutorIdprotected booleanfinishedprotected static org.slf4j.Loggerlogprotected static AtomicLongNEXT_EXECUTOR_IDprotected QueryInfoqueryInfoprotected CloseableIteration<T>rightIterprotected FedXQueueCursor<T>rightQueueprotected FederationEvalStrategystrategy
 - 
Constructor SummaryConstructors Constructor Description ParallelExecutorBase(QueryInfo queryInfo)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddResult(CloseableIteration<T> res)Handle the result appropriately, e.g.protected voidcheckTimeout()Checks whether the query execution has run into a timeout.voiddone()Inform the controlling instance that some job is done from a different thread.StringgetDisplayId()protected StringgetExecutorType()protected StringgetId()TgetNextElement()Gets the next element.QueryInfogetQueryInfo()Return the query info of the associated queryvoidhandleClose()Called byAbstractCloseableIteration.close()when it is called for the first time.booleanisFinished()Return true if this executor is finished or abortedprotected abstract voidperformExecution()Perform the parallel execution.voidrun()voidtoss(Exception e)Toss some exception to the controlling instanceStringtoString()- 
Methods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, remove
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosed
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.common.iteration.CloseableIterationstream
 - 
Methods inherited from interface java.util.IteratorforEachRemaining
 
- 
 
- 
- 
- 
Field Detail- 
logprotected static final org.slf4j.Logger log 
 - 
NEXT_EXECUTOR_IDprotected static final AtomicLong NEXT_EXECUTOR_ID 
 - 
strategyprotected final FederationEvalStrategy strategy 
 - 
executorIdprotected final long executorId 
 - 
queryInfoprotected final QueryInfo queryInfo 
 - 
evaluationThreadprotected volatile Thread evaluationThread 
 - 
rightQueueprotected FedXQueueCursor<T> rightQueue 
 - 
rightIterprotected volatile CloseableIteration<T> rightIter 
 - 
finishedprotected volatile boolean finished 
 
- 
 - 
Constructor Detail- 
ParallelExecutorBasepublic ParallelExecutorBase(QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 - 
Method Detail- 
performExecutionprotected abstract void performExecution() throws ExceptionPerform the parallel execution.Note that this method must block until the execution is completed. - Throws:
- Exception
 
 - 
addResultpublic void addResult(CloseableIteration<T> res) Description 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>
 
 - 
tosspublic void toss(Exception e) Description copied from interface:ParallelExecutorToss some exception to the controlling instance- Specified by:
- tossin interface- ParallelExecutor<T>
 
 - 
getNextElementpublic T getNextElement() throws QueryEvaluationException Description 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
 
 - 
checkTimeoutprotected void checkTimeout() throws QueryInterruptedExceptionChecks whether the query execution has run into a timeout. If so, aQueryInterruptedExceptionis thrown.- Throws:
- QueryInterruptedException
 
 - 
handleClosepublic void handleClose() throws QueryEvaluationExceptionDescription 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
 
 - 
getQueryInfopublic QueryInfo getQueryInfo() Description copied from interface:ParallelExecutorReturn the query info of the associated query- Specified by:
- getQueryInfoin interface- ParallelExecutor<T>
- Returns:
- the query info
 
 - 
getIdprotected String getId() - Returns:
- a unique identifier of this execution
 
 - 
getDisplayIdpublic String getDisplayId() 
 - 
getExecutorTypeprotected String getExecutorType() - Returns:
- the executor type, e.g. "Join". Default "Executor"
 
 
- 
 
-