Class ControlledWorkerLeftJoin
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<BindingSet>
org.eclipse.rdf4j.federated.evaluation.join.ControlledWorkerLeftJoin
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- Iterator<BindingSet>,- CloseableIteration<BindingSet>,- ParallelExecutor<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 a 
ControlledWorkerScheduler which 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 SummaryFieldsModifier and TypeFieldDescriptionprotected final LeftJoinprotected final Phaserprotected final ControlledWorkerScheduler<BindingSet>Fields inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasebindings, joinVars, leftIter, rightArgFields inherited from class org.eclipse.rdf4j.federated.evaluation.concurrent.ParallelExecutorBaseevaluationThread, executorId, finished, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
- 
Constructor SummaryConstructorsConstructorDescriptionControlledWorkerLeftJoin(ControlledWorkerScheduler<BindingSet> scheduler, FederationEvalStrategy strategy, CloseableIteration<BindingSet> leftIter, LeftJoin join, BindingSet bindings, QueryInfo queryInfo) 
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidImplementations must implement this method to handle bindings.voidCalled byAbstractCloseableIteration.close()when it is called for the first time.Methods inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasegetExecutorType, getJoinVars, performExecution, setJoinVarsMethods 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- 
scheduler
- 
phaser
- 
join
 
- 
- 
Constructor Details- 
ControlledWorkerLeftJoinpublic ControlledWorkerLeftJoin(ControlledWorkerScheduler<BindingSet> scheduler, FederationEvalStrategy strategy, CloseableIteration<BindingSet> leftIter, LeftJoin join, BindingSet bindings, QueryInfo queryInfo) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
- 
Method Details- 
handleBindingsDescription 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
 
- 
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- JoinExecutorBase<BindingSet>
- Throws:
- QueryEvaluationException
 
 
-