Package org.apache.druid.segment.data
Class FrontCodedIntArrayIndexedWriter
- java.lang.Object
-
- org.apache.druid.segment.data.FrontCodedIntArrayIndexedWriter
-
- All Implemented Interfaces:
DictionaryWriter<int[]>,Serializer
public class FrontCodedIntArrayIndexedWriter extends Object implements DictionaryWriter<int[]>
-
-
Field Summary
Fields Modifier and Type Field Description static Comparator<int[]>ARRAY_COMPARATOR
-
Constructor Summary
Constructors Constructor Description FrontCodedIntArrayIndexedWriter(SegmentWriteOutMedium segmentWriteOutMedium, ByteOrder byteOrder, int bucketSize)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description int[]get(int index)Returns an object that has already been written via theDictionaryWriter.write(T)method.intgetCardinality()Returns the number of items that have been written so far in this dictionary.longgetSerializedSize()Returns the number of bytes, that this Serializer will write to the output _channel_ (not smoosher) on aSerializer.writeTo(java.nio.channels.WritableByteChannel, org.apache.druid.java.util.common.io.smoosh.FileSmoosher)call.booleanisSorted()voidopen()Prepares the writer for writingintwrite(int[] value)Writes an object to the dictionary.static intwriteBucket(ByteBuffer buffer, int[][] values, int numValues)Write bucket of values to aByteBuffer.voidwriteTo(WritableByteChannel channel, FileSmoosher smoosher)Writes the serialized form of this object.static intwriteValue(ByteBuffer buffer, int[] ints)Write a variable length int[] value to aByteBuffer, storing the length as aVByteencoded integer followed by the value itself.
-
-
-
Field Detail
-
ARRAY_COMPARATOR
public static final Comparator<int[]> ARRAY_COMPARATOR
-
-
Constructor Detail
-
FrontCodedIntArrayIndexedWriter
public FrontCodedIntArrayIndexedWriter(SegmentWriteOutMedium segmentWriteOutMedium, ByteOrder byteOrder, int bucketSize)
-
-
Method Detail
-
open
public void open() throws IOExceptionDescription copied from interface:DictionaryWriterPrepares the writer for writing- Specified by:
openin interfaceDictionaryWriter<int[]>- Throws:
IOException- if there is a problem with IO
-
write
public int write(@Nullable int[] value) throws IOException
Description copied from interface:DictionaryWriterWrites an object to the dictionary.Returns the index of the value that was just written. This is defined as the `int` value that can be passed into
DictionaryWriter.get(int)such that it will return the same value back.- Specified by:
writein interfaceDictionaryWriter<int[]>- Parameters:
value- object to be written to the dictionary- Returns:
- index of the value that was just written
- Throws:
IOException- if there is a problem with IO
-
getSerializedSize
public long getSerializedSize() throws IOExceptionDescription copied from interface:SerializerReturns the number of bytes, that this Serializer will write to the output _channel_ (not smoosher) on aSerializer.writeTo(java.nio.channels.WritableByteChannel, org.apache.druid.java.util.common.io.smoosh.FileSmoosher)call.- Specified by:
getSerializedSizein interfaceSerializer- Throws:
IOException
-
writeTo
public void writeTo(WritableByteChannel channel, FileSmoosher smoosher) throws IOException
Description copied from interface:SerializerWrites the serialized form of this object. The entire object may be written to the provided channel, or the object may be split over the provided channel and files added to the {@link FileSmoosher], where additional channels can be created viaFileSmoosher.addWithSmooshedWriter(String, long). The latter approach is useful when the serialized form of the object is too large for a single smoosh container. At the time this javadoc was written, the max smoosh container size is limit to the maxByteBuffersize.- Specified by:
writeToin interfaceSerializer- Throws:
IOException
-
isSorted
public boolean isSorted()
- Specified by:
isSortedin interfaceDictionaryWriter<int[]>
-
get
@Nullable public int[] get(int index) throws IOException
Description copied from interface:DictionaryWriterReturns an object that has already been written via theDictionaryWriter.write(T)method.- Specified by:
getin interfaceDictionaryWriter<int[]>- Parameters:
index- index of the object to return- Returns:
- the object identified by the given index
- Throws:
IOException- if there is a problem with IO
-
getCardinality
public int getCardinality()
Description copied from interface:DictionaryWriterReturns the number of items that have been written so far in this dictionary. Any number lower than this cardinality can be passed intoDictionaryWriter.get(int)and a value will be returned. If a value greater than or equal to the cardinality is passed intoDictionaryWriter.get(int)all sorts of things could happen, but likely none of them are good.- Specified by:
getCardinalityin interfaceDictionaryWriter<int[]>- Returns:
- the number of items that have been written so far
-
writeBucket
public static int writeBucket(ByteBuffer buffer, int[][] values, int numValues)
Write bucket of values to aByteBuffer. The first value is written completely, subsequent values are written with an integer to indicate how much of the first value in the bucket is a prefix of the value, followed by the remaining bytes of the value. UsesVByteencoded integers to indicate prefix length and value length.
-
writeValue
public static int writeValue(ByteBuffer buffer, int[] ints)
Write a variable length int[] value to aByteBuffer, storing the length as aVByteencoded integer followed by the value itself. Returns the number of bytes written to the buffer. This method returns a negative value if there is no room available in the buffer, so that it can be grown if needed.
-
-