Class SynchronousJoin
- 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.SynchronousJoin
 
 
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- Runnable,- Iterator<BindingSet>,- CloseableIteration<BindingSet>,- ParallelExecutor<BindingSet>
 - Direct Known Subclasses:
- SynchronousBoundJoin
 
 public class SynchronousJoin extends JoinExecutorBase<BindingSet> Execute the nested loop join in a synchronous fashion, i.e. one binding after the other- Author:
- Andreas Schwarte
 
- 
- 
Field Summary- 
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, log, NEXT_EXECUTOR_ID, queryInfo, rightIter, rightQueue, strategy
 
- 
 - 
Constructor SummaryConstructors Constructor Description SynchronousJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet> 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.- 
Methods inherited from class org.eclipse.rdf4j.federated.evaluation.join.JoinExecutorBasegetExecutorType, getJoinVars, handleClose, 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
 - 
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
 
- 
 
- 
- 
- 
Constructor Detail- 
SynchronousJoinpublic SynchronousJoin(FederationEvalStrategy strategy, CloseableIteration<BindingSet> 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
 
 
- 
 
-