public class NullValueArray extends Object implements ValueArray<NullValue>
NullValue
.Constructor and Description |
---|
NullValueArray()
Initializes an expandable array with default capacity.
|
NullValueArray(int bytes)
Initializes a fixed-size array with the provided number of bytes.
|
Modifier and Type | Method and Description |
---|---|
boolean |
add(NullValue value)
Appends the value to this array if and only if the array capacity would not be exceeded.
|
boolean |
addAll(ValueArray<NullValue> other)
Appends all of the values in the specified array to the end of this array.
|
void |
clear()
Resets the array to the empty state.
|
int |
compareTo(ValueArray<NullValue> o) |
ValueArray<NullValue> |
copy()
Performs a deep copy of this object into a new instance.
|
void |
copy(DataInputView source,
DataOutputView target)
Copies the next serialized instance from
source to target . |
void |
copyNormalizedKey(MemorySegment target,
int offset,
int len)
Writes a normalized key for the given record into the target byte array, starting at the
specified position an writing exactly the given number of bytes.
|
void |
copyTo(ValueArray<NullValue> target)
Performs a deep copy of this object into the
target instance. |
boolean |
equals(Object obj)
Compares the object on equality with another object.
|
int |
getBinaryLength()
Gets the length of the data type when it is serialized, in bytes.
|
int |
getMaxNormalizedKeyLen()
Gets the maximal length of normalized keys that the data type would produce to determine the
order of instances solely by the normalized key.
|
int |
hashCode()
All keys must override the hash-code function to generate proper deterministic hash codes,
based on their contents.
|
boolean |
isFull()
An bounded array fills when the allocated capacity has been fully used.
|
Iterator<NullValue> |
iterator() |
void |
mark()
Saves the array index, which can be restored by calling
reset() . |
void |
read(DataInputView in)
Reads the object's internal data from the given data input view.
|
void |
reset()
Restores the array index to when
mark() was last called. |
void |
setValue(ValueArray<NullValue> value)
Sets the encapsulated value to another value
|
int |
size()
Returns the number of elements stored in the array.
|
String |
toString() |
void |
write(DataOutputView out)
Writes the object's internal data to the given data output view.
|
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
forEach, spliterator
public NullValueArray()
public NullValueArray(int bytes)
bytes
- number of bytes of the encapsulated arraypublic void write(DataOutputView out) throws IOException
IOReadableWritable
write
in interface IOReadableWritable
out
- the output view to receive the data.IOException
- thrown if any error occurs while writing to the output streampublic void read(DataInputView in) throws IOException
IOReadableWritable
read
in interface IOReadableWritable
in
- the input view to read the data fromIOException
- thrown if any error occurs while reading from the input streampublic int getMaxNormalizedKeyLen()
NormalizableKey
Integer
.MAX_VALUE is interpreted as infinite.
For example, 32 bit integers return four, while Strings (potentially unlimited in length)
return Integer
.MAX_VALUE.
getMaxNormalizedKeyLen
in interface NormalizableKey<ValueArray<NullValue>>
public void copyNormalizedKey(MemorySegment target, int offset, int len)
NormalizableKey
int byteI = bytes[i] & 0xFF;
If the meaningful part of the normalized key takes less than the given number of bytes,
then it must be padded. Padding is typically required for variable length data types, such as
strings. The padding uses a special character, either 0
or 0xff
, depending on
whether shorter values are sorted to the beginning or the end.
copyNormalizedKey
in interface NormalizableKey<ValueArray<NullValue>>
target
- The memory segment to put the normalized key bytes into.offset
- The offset in the byte array where the normalized key's bytes should start.len
- The number of bytes to put.public int compareTo(ValueArray<NullValue> o)
compareTo
in interface Comparable<ValueArray<NullValue>>
public int hashCode()
Key
public boolean equals(Object obj)
Key
public void setValue(ValueArray<NullValue> value)
ResettableValue
setValue
in interface ResettableValue<ValueArray<NullValue>>
value
- the new value of the encapsulated valuepublic int getBinaryLength()
CopyableValue
getBinaryLength
in interface CopyableValue<ValueArray<NullValue>>
-1
, if variable length.public void copyTo(ValueArray<NullValue> target)
CopyableValue
target
instance.copyTo
in interface CopyableValue<ValueArray<NullValue>>
target
- Object to copy into.public ValueArray<NullValue> copy()
CopyableValue
This method is useful for generic user-defined functions to clone a CopyableValue
when storing multiple objects. With object reuse a deep copy must be created and type erasure
prevents calling new.
copy
in interface CopyableValue<ValueArray<NullValue>>
public void copy(DataInputView source, DataOutputView target) throws IOException
CopyableValue
source
to target
.
This method is equivalent to calling IOReadableWritable.read(DataInputView)
followed by IOReadableWritable.write(DataOutputView)
but does not require
intermediate deserialization.
copy
in interface CopyableValue<ValueArray<NullValue>>
source
- Data source for serialized instance.target
- Data target for serialized instance.IOException
IOReadableWritable
public int size()
ValueArray
size
in interface ValueArray<NullValue>
public boolean isFull()
ValueArray
isFull
in interface ValueArray<NullValue>
public boolean add(NullValue value)
ValueArray
add
in interface ValueArray<NullValue>
value
- the value to add to this arraypublic boolean addAll(ValueArray<NullValue> other)
ValueArray
addAll
in interface ValueArray<NullValue>
other
- array containing values to be added to this arraypublic void clear()
ValueArray
This may reset the ValueArray.mark()
in order to allow arrays be shrunk.
clear
in interface ValueArray<NullValue>
public void mark()
ValueArray
reset()
.
This is not serialized and is not part of the contract for Key.equals(Object)
.
mark
in interface ValueArray<NullValue>
public void reset()
ValueArray
mark()
was last called.reset
in interface ValueArray<NullValue>
Copyright © 2014–2021 The Apache Software Foundation. All rights reserved.