Class RangeUnionIterator<K extends java.lang.Comparable<K>,D extends CombinedValue<K>>
- java.lang.Object
-
- org.apache.cassandra.utils.AbstractGuavaIterator<T>
-
- org.apache.cassandra.index.sasi.utils.RangeIterator<K,D>
-
- org.apache.cassandra.index.sasi.utils.RangeUnionIterator<K,D>
-
- Type Parameters:
K
- The type used to sort ranges.D
- The container type which is going to be returned byIterator.next()
.
- All Implemented Interfaces:
com.google.common.collect.PeekingIterator<D>
,java.io.Closeable
,java.lang.AutoCloseable
,java.util.Iterator<D>
public class RangeUnionIterator<K extends java.lang.Comparable<K>,D extends CombinedValue<K>> extends RangeIterator<K,D>
Range Union Iterator is used to return sorted stream of elements from multiple RangeIterator instances. PriorityQueue is used as a sorting mechanism for the ranges, where each computeNext() operation would poll from the queue (and push when done), which returns range that contains the smallest element, because sorting is done on the moving window of range iterationRangeIterator.getCurrent()
. Once retrieved the smallest element (return candidate) is attempted to be merged with other ranges, because there could be equal elements in adjacent ranges, such ranges are poll'ed only if theirRangeIterator.getCurrent()
equals to the return candidate.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static class
RangeUnionIterator.Builder<K extends java.lang.Comparable<K>,D extends CombinedValue<K>>
-
Nested classes/interfaces inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
AbstractGuavaIterator.State
-
-
Field Summary
-
Fields inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
next, state
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static <K extends java.lang.Comparable<K>,D extends CombinedValue<K>>
RangeIterator<K,D>build(java.util.List<RangeIterator<K,D>> tokens)
static <K extends java.lang.Comparable<K>,D extends CombinedValue<K>>
RangeUnionIterator.Builder<K,D>builder()
void
close()
D
computeNext()
Returns the next element.protected void
performSkipTo(K nextToken)
-
Methods inherited from class org.apache.cassandra.index.sasi.utils.RangeIterator
getCount, getCurrent, getMaximum, getMinimum, isOverlapping, isOverlapping, recomputeNext, skipTo, tryToComputeNext
-
Methods inherited from class org.apache.cassandra.utils.AbstractGuavaIterator
endOfData, hasNext, next, peek, remove
-
-
-
-
Method Detail
-
computeNext
public D computeNext()
Description copied from class:AbstractGuavaIterator
Returns the next element. Note: the implementation must callAbstractGuavaIterator.endOfData()
when there are no elements left in the iteration. Failure to do so could result in an infinite loop.The initial invocation of
AbstractGuavaIterator.hasNext()
orAbstractGuavaIterator.next()
calls this method, as does the first invocation ofhasNext
ornext
following each successful call tonext
. Once the implementation either invokesendOfData
or throws an exception,computeNext
is guaranteed to never be called again.If this method throws an exception, it will propagate outward to the
hasNext
ornext
invocation that invoked this method. Any further attempts to use the iterator will result in anIllegalStateException
.The implementation of this method may not invoke the
hasNext
,next
, orAbstractGuavaIterator.peek()
methods on this instance; if it does, anIllegalStateException
will result.- Specified by:
computeNext
in classAbstractGuavaIterator<D extends CombinedValue<K>>
- Returns:
- the next element if there was one. If
endOfData
was called during execution, the return value will be ignored.
-
performSkipTo
protected void performSkipTo(K nextToken)
- Specified by:
performSkipTo
in classRangeIterator<K extends java.lang.Comparable<K>,D extends CombinedValue<K>>
-
close
public void close() throws java.io.IOException
- Throws:
java.io.IOException
-
builder
public static <K extends java.lang.Comparable<K>,D extends CombinedValue<K>> RangeUnionIterator.Builder<K,D> builder()
-
build
public static <K extends java.lang.Comparable<K>,D extends CombinedValue<K>> RangeIterator<K,D> build(java.util.List<RangeIterator<K,D>> tokens)
-
-