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_ACCOUNTABLEFields inherited from interface org.apache.lucene.util.Bits
EMPTY_ARRAY -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionabstract intReturn an approximation of the cardinality of this set.abstract intReturn the number of bits that are set.protected final voidAssert that the current doc is -1.voidclear()Clear all the bits of the set.abstract voidclear(int i) Clear the bit ati.abstract voidclear(int startIndex, int endIndex) Clears a range of bits.abstract booleangetAndSet(int i) Set the bit ati, returningtrueif it was previously set.intnextSetBit(int index) Returns the index of the first set bit starting at the index specified.abstract intnextSetBit(int start, int end) Returns the index of the first set bit from start (inclusive) until end (exclusive).static BitSetof(DocIdSetIterator it, int maxDoc) Build aBitSetfrom the content of the providedDocIdSetIterator.voidor(DocIdSetIterator iter) Does in-place OR of the bits provided by the iterator.abstract intprevSetBit(int index) Returns the index of the last set bit before or on the index specified.abstract voidset(int i) Set the bit ati.Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface org.apache.lucene.util.Accountable
getChildResources, ramBytesUsed
-
Constructor Details
-
BitSet
public BitSet()
-
-
Method Details
-
of
Build aBitSetfrom the content of the providedDocIdSetIterator. NOTE: this will fully consume theDocIdSetIterator.- Throws:
IOException
-
clear
public void clear()Clear all the bits of the set.Depending on the implementation, this may be significantly faster than clear(0, length).
-
set
public abstract void set(int i) Set the bit ati. -
getAndSet
public abstract boolean getAndSet(int i) Set the bit ati, returningtrueif 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 int nextSetBit(int index) Returns the index of the first set bit starting at the index specified.DocIdSetIterator.NO_MORE_DOCSis returned if there are no more set bits. -
nextSetBit
public abstract int nextSetBit(int start, int end) Returns the index of the first set bit from start (inclusive) until end (exclusive).DocIdSetIterator.NO_MORE_DOCSis 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
-