Class JoinExecutorBase<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>
org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBase<T>
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- Iterator<T>,- CloseableIteration<T>,- ParallelExecutor<T>
- Direct Known Subclasses:
- ControlledWorkerBindJoinBase,- ControlledWorkerJoin,- ControlledWorkerLeftJoin,- HashJoin,- SynchronousJoin
Base class for any join parallel join executor.
 Note that this class extends 
LookAheadIteration and thus any implementation of this class is applicable for
 pipelining when used in a different thread (access to shared variables is synchronized).- Author:
- Andreas Schwarte
- 
Field SummaryFieldsModifier and TypeFieldDescriptionprotected final BindingSetprotected CloseableIteration<T>protected final TupleExprFields inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseevaluationThread, executorId, finished, log, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
- 
Constructor SummaryConstructorsConstructorDescriptionJoinExecutorBase(FederationEvalStrategy strategy, CloseableIteration<T> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo) 
- 
Method SummaryModifier and TypeMethodDescriptionprotected Stringprotected abstract voidImplementations must implement this method to handle bindings.voidCalled byAbstractCloseableIteration.close()when it is called for the first time.protected final voidPerform the parallel execution.voidsetJoinVars(Set<String> joinVars) Set the join variablesMethods inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseaddResult, checkTimeout, done, getDisplayId, getId, getNextElement, getQueryInfo, isFinished, run, toss, toStringMethods 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- 
rightArg
- 
bindings
- 
joinVars
- 
leftIter
 
- 
- 
Constructor Details- 
JoinExecutorBasepublic JoinExecutorBase(FederationEvalStrategy strategy, CloseableIteration<T> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
- 
Method Details- 
performExecutionDescription copied from class:ParallelExecutorBasePerform the parallel execution.Note that this method must block until the execution is completed. - Specified by:
- performExecutionin class- ParallelExecutorBase<T>
- Throws:
- Exception
 
- 
handleBindingsImplementations must implement this method to handle bindings. Use the following as a templatewhile (!closed && leftIter.hasNext()) { // your code }and add results to rightQueue. Note that addResult() is implemented synchronized and thus thread safe. In case you can guarantee sequential access, it is also possible to directly access rightQueue Note that the implementation must block until the entire join is executed.- Throws:
- Exception
 
- 
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.- Overrides:
- handleClosein class- ParallelExecutorBase<T>
- Throws:
- QueryEvaluationException
 
- 
getExecutorType- Overrides:
- getExecutorTypein class- ParallelExecutorBase<T>
- Returns:
- the executor type, e.g. "Join". Default "Executor"
 
- 
getJoinVars- Returns:
- the join variables, might be nullif unknown in the concrete implementation
 
- 
setJoinVarsSet the join variables- Parameters:
- joinVars- the join variables
 
 
-