Package org.apache.lucene.util
Class BitSet
java.lang.Object
org.apache.lucene.util.BitSet
- All Implemented Interfaces:
Accountable
,Bits
- Direct Known Subclasses:
FixedBitSet
,SparseFixedBitSet
Base implementation for a bit set.
- NOTE: This API is for internal purposes only and might change in incompatible ways in the next release.
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.apache.lucene.util.Bits
Bits.MatchAllBits, Bits.MatchNoBits
-
Field Summary
Fields inherited from interface org.apache.lucene.util.Accountable
NULL_ACCOUNTABLE
Fields inherited from interface org.apache.lucene.util.Bits
EMPTY_ARRAY
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionabstract int
Return an approximation of the cardinality of this set.abstract int
Return the number of bits that are set.protected final void
Assert that the current doc is -1.abstract void
clear
(int i) Clear the bit ati
.abstract void
clear
(int startIndex, int endIndex) Clears a range of bits.abstract boolean
getAndSet
(int i) Set the bit ati
, returningtrue
if it was previously set.abstract int
nextSetBit
(int index) Returns the index of the first set bit starting at the index specified.static BitSet
of
(DocIdSetIterator it, int maxDoc) Build aBitSet
from the content of the providedDocIdSetIterator
.void
or
(DocIdSetIterator iter) Does in-place OR of the bits provided by the iterator.abstract int
prevSetBit
(int index) Returns the index of the last set bit before or on the index specified.abstract void
set
(int i) Set the bit ati
.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.apache.lucene.util.Accountable
getChildResources, ramBytesUsed
-
Constructor Details
-
BitSet
public BitSet()
-
-
Method Details
-
of
Build aBitSet
from the content of the providedDocIdSetIterator
. NOTE: this will fully consume theDocIdSetIterator
.- Throws:
IOException
-
set
public abstract void set(int i) Set the bit ati
. -
getAndSet
public abstract boolean getAndSet(int i) Set the bit ati
, returningtrue
if it was previously set. -
clear
public abstract void clear(int i) Clear the bit ati
. -
clear
public abstract void clear(int startIndex, int endIndex) Clears a range of bits.- Parameters:
startIndex
- lower indexendIndex
- one-past the last bit to clear
-
cardinality
public abstract int cardinality()Return the number of bits that are set. NOTE: this method is likely to run in linear time -
approximateCardinality
public abstract int approximateCardinality()Return an approximation of the cardinality of this set. Some implementations may trade accuracy for speed if they have the ability to estimate the cardinality of the set without iterating over all the data. The default implementation returnscardinality()
. -
prevSetBit
public abstract int prevSetBit(int index) Returns the index of the last set bit before or on the index specified. -1 is returned if there are no more set bits. -
nextSetBit
public abstract int nextSetBit(int index) Returns the index of the first set bit starting at the index specified.DocIdSetIterator.NO_MORE_DOCS
is returned if there are no more set bits. -
checkUnpositioned
Assert that the current doc is -1. -
or
Does in-place OR of the bits provided by the iterator. The state of the iterator after this operation terminates is undefined.- Throws:
IOException
-