Class ObjectArraySerializer<E>
java.lang.Object
org.djutils.serialization.serializers.BasicSerializer<T>
org.djutils.serialization.serializers.ArrayOrMatrixSerializer<E[],E>
org.djutils.serialization.serializers.ObjectArraySerializer<E>
- Type Parameters:
E
- class of the element object
- All Implemented Interfaces:
Serializer<E[]>
Serializer for Object array classes.
Copyright (c) 2019-2024 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
BSD-style license. See DJUTILS License.
- Author:
- Alexander Verbraeck, Peter Knoppers
-
Constructor Summary
ConstructorDescriptionObjectArraySerializer
(byte type, int dataSize, E sample, String dataClassName) Construct a new ObjectArraySerializer. -
Method Summary
Modifier and TypeMethodDescriptionfinal E[]
deSerialize
(byte[] buffer, Pointer pointer, EndianUtil endianUtil) Deserialize an object of type T.final void
serialize
(E[] array, byte[] buffer, Pointer pointer, EndianUtil endianUtil) Serialize an object of type T; not including the prefix byte(s).final void
serializeWithPrefix
(E[] array, byte[] buffer, Pointer pointer, EndianUtil endianUtil) Serialize an object of type T including the prefix byte(s).final int
Compute the number of bytes needed to serialize an object of type T (excluding the byte(s) that indicate that an object of type T is next in the data stream).final int
sizeWithPrefix
(E[] array) Compute the number of bytes needed to serialize an object of type T (including the byte(s) that indicate that an object of type T is next in the data stream).Methods inherited from class org.djutils.serialization.serializers.ArrayOrMatrixSerializer
deSerializeElement, getElementSize, getNumberOfDimensions, serializeElement
Methods inherited from class org.djutils.serialization.serializers.BasicSerializer
dataClassName, fieldType, toString
-
Constructor Details
-
ObjectArraySerializer
Construct a new ObjectArraySerializer.- Parameters:
type
- byte; the field type (returned by thefieldType
method)dataSize
- int; the number of bytes needed to encode one additional array elementsample
- E; sample object (can be zero length array).dataClassName
- String; returned by the dataClassName method
-
-
Method Details
-
size
Description copied from interface:Serializer
Compute the number of bytes needed to serialize an object of type T (excluding the byte(s) that indicate that an object of type T is next in the data stream).- Parameters:
array
- T; Instance of the object- Returns:
- int; the number of bytes needed to serialize an object of type T
-
sizeWithPrefix
Description copied from interface:Serializer
Compute the number of bytes needed to serialize an object of type T (including the byte(s) that indicate that an object of type T is next in the data stream).- Parameters:
array
- T; Instance of the object- Returns:
- int; the number of bytes needed to serialize an object of type T
-
serializeWithPrefix
public final void serializeWithPrefix(E[] array, byte[] buffer, Pointer pointer, EndianUtil endianUtil) throws SerializationException Description copied from interface:Serializer
Serialize an object of type T including the prefix byte(s).- Parameters:
array
- T; the object to serializebuffer
- byte[]; buffer for the serialized Tpointer
- Pointer; position in buffer where the first byte of the serialized T will be storedendianUtil
- EndianUtil; selects bigEndian or littleEndian encoding- Throws:
SerializationException
- when a matrix has size zero or is jagged
-
serialize
Description copied from interface:Serializer
Serialize an object of type T; not including the prefix byte(s).- Parameters:
array
- T; the object to serializebuffer
- byte[]; buffer for the serialized Tpointer
- Pointer; position in buffer where the first byte of the serialized T will be storedendianUtil
- EndianUtil; selects bigEndian or littleEndian encoding
-
deSerialize
Description copied from interface:Serializer
Deserialize an object of type T. Thepointer
should be on the first byte of the object; i.e. just after the prefix byte.- Parameters:
buffer
- byte[]; the bytes with serialized data that must be reconstructed into a Tpointer
- Pointer; position in the buffer where the first byte of the serialized T is locatedendianUtil
- EndianUtil; selects bigEndian or littleEndian encoding- Returns:
- T; a T object constructed from the data in the buffer
-