Class ControlledWorkerJoin
- java.lang.Object
- 
- org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E,X>
- 
- org.eclipse.rdf4j.common.iteration.LookAheadIteration<T,QueryEvaluationException>
- 
- org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBase<T>
- 
- org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBase<BindingSet>
- 
- org.eclipse.rdf4j.federated.evaluation.join.ControlledWorkerJoin
 
 
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- CloseableIteration<BindingSet,QueryEvaluationException>,- Iteration<BindingSet,QueryEvaluationException>,- ParallelExecutor<BindingSet>
 - Direct Known Subclasses:
- ControlledWorkerBoundJoin
 
 public class ControlledWorkerJoin extends JoinExecutorBase<BindingSet> Execute the nested loop join in an asynchronous fashion, i.e. one binding after the other (but concurrently) The number of concurrent threads is controlled by aControlledWorkerSchedulerwhich works according to the FIFO principle. This join cursor blocks until all scheduled tasks are finished, however the result iteration can be accessed from different threads to allow for pipelining.- Author:
- Andreas Schwarte
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected Phaserphaserprotected ControlledWorkerScheduler<BindingSet>scheduler- 
Fields inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasebindings, joinVars, leftIter, rightArg
 - 
Fields inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseevaluationThread, executorId, finished, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
 
- 
 - 
Constructor SummaryConstructors Constructor Description ControlledWorkerJoin(ControlledWorkerScheduler<BindingSet> scheduler, FederationEvalStrategy strategy, CloseableIteration<BindingSet,QueryEvaluationException> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo)
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description protected voidhandleBindings()Implementations must implement this method to handle bindings.voidhandleClose()Called byAbstractCloseableIteration.close()when it is called for the first time.- 
Methods inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasegetExecutorType, getJoinVars, performExecution, setJoinVars
 - 
Methods inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseaddResult, checkTimeout, done, getDisplayId, getId, getNextElement, getQueryInfo, isFinished, run, toss, toString
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.LookAheadIterationhasNext, next, remove
 - 
Methods inherited from class org.eclipse.rdf4j.common.iteration.AbstractCloseableIterationclose, isClosed
 
- 
 
- 
- 
- 
Field Detail- 
schedulerprotected final ControlledWorkerScheduler<BindingSet> scheduler 
 - 
phaserprotected final Phaser phaser 
 
- 
 - 
Constructor Detail- 
ControlledWorkerJoinpublic ControlledWorkerJoin(ControlledWorkerScheduler<BindingSet> scheduler, FederationEvalStrategy strategy, CloseableIteration<BindingSet,QueryEvaluationException> leftIter, TupleExpr rightArg, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 - 
Method Detail- 
handleBindingsprotected void handleBindings() throws ExceptionDescription copied from class:JoinExecutorBaseImplementations 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.- Specified by:
- handleBindingsin class- JoinExecutorBase<BindingSet>
- Throws:
- Exception
 
 - 
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.- Overrides:
- handleClosein class- JoinExecutorBase<BindingSet>
- Throws:
- QueryEvaluationException
 
 
- 
 
-