Class JoinExecutorBase<T>
- java.lang.Object
- 
- org.eclipse.rdf4j.common.iteration.AbstractCloseableIteration<E,X>
- 
- org.eclipse.rdf4j.common.iteration.LookAheadIteration<T,QueryEvaluationException>
- 
- org.eclipse.rdf4j.repository.sparql.federation.JoinExecutorBase<T>
 
 
 
- 
- All Implemented Interfaces:
- AutoCloseable,- CloseableIteration<T,QueryEvaluationException>,- Iteration<T,QueryEvaluationException>
 - Direct Known Subclasses:
- JoinExecutorBase
 
 public abstract class JoinExecutorBase<T> extends LookAheadIteration<T,QueryEvaluationException> Base class for any join parallel join executor. Note that this class extendsLookAheadIterationand 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 SummaryFields Modifier and Type Field Description protected BindingSetbindingsprotected booleanclosedDeprecated.UseAbstractCloseableIteration.isClosed()instead.protected booleanfinishedDeprecated.UseisFinished()instead.protected CloseableIteration<T,QueryEvaluationException>leftIterprotected static intNEXT_JOIN_IDDeprecated.No replacement, don't use static shared int variables.protected TupleExprrightArgprotected CloseableIteration<T,QueryEvaluationException>rightIterprotected QueueCursor<CloseableIteration<T,QueryEvaluationException>>rightQueue
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedJoinExecutorBase(CloseableIteration<T,QueryEvaluationException> leftIter, TupleExpr rightArg, BindingSet bindings)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddResult(CloseableIteration<T,QueryEvaluationException> res)voiddone()TgetNextElement()Gets the next element.protected abstract voidhandleBindings()Implementations must implement this method to handle bindings.voidhandleClose()Called byAbstractCloseableIteration.close()when it is called for the first time.booleanisFinished()Gets whether this executor is finished or aborted.voidrun()voidtoss(Exception e)- 
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, toString, wait, wait, wait
 - 
Methods inherited from interface org.eclipse.rdf4j.common.iteration.CloseableIterationstream
 
- 
 
- 
- 
- 
Field Detail- 
NEXT_JOIN_IDprotected static int NEXT_JOIN_ID Deprecated.No replacement, don't use static shared int variables.
 - 
rightArgprotected final TupleExpr rightArg 
 - 
bindingsprotected final BindingSet bindings 
 - 
leftIterprotected final CloseableIteration<T,QueryEvaluationException> leftIter 
 - 
rightIterprotected volatile CloseableIteration<T,QueryEvaluationException> rightIter 
 - 
closedprotected volatile boolean closed Deprecated.UseAbstractCloseableIteration.isClosed()instead.
 - 
finishedprotected volatile boolean finished Deprecated.UseisFinished()instead.
 - 
rightQueueprotected final QueueCursor<CloseableIteration<T,QueryEvaluationException>> rightQueue 
 
- 
 - 
Constructor Detail- 
JoinExecutorBaseprotected JoinExecutorBase(CloseableIteration<T,QueryEvaluationException> leftIter, TupleExpr rightArg, BindingSet bindings) throws QueryEvaluationException - Throws:
- QueryEvaluationException
 
 
- 
 - 
Method Detail- 
runpublic final void run() 
 - 
handleBindingsprotected abstract void handleBindings() throws ExceptionImplementations 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- Throws:
- Exception
 
 - 
addResultpublic void addResult(CloseableIteration<T,QueryEvaluationException> res) 
 - 
donepublic void done() 
 - 
tosspublic void toss(Exception e) 
 - 
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,QueryEvaluationException>
- Returns:
- The next element, or null if no more elements are available.
- Throws:
- QueryEvaluationException
 
 - 
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- LookAheadIteration<T,QueryEvaluationException>
- Throws:
- QueryEvaluationException
 
 - 
isFinishedpublic boolean isFinished() Gets whether this executor is finished or aborted.- Returns:
- true if this executor is finished or aborted
 
 
- 
 
-