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[]>
public abstract class ObjectArraySerializer<E> extends ArrayOrMatrixSerializer<E[],E>
Serializer for Object array classes.
Copyright (c) 2019-2020 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
BSD-style license. See OpenTrafficSim License.
- Version:
- $Revision$, $LastChangedDate$, by $Author$,
- Author:
- Alexander Verbraeck, Peter Knoppers, Wouter Schakel
-
Constructor Summary
Constructors Constructor Description ObjectArraySerializer(byte type, int dataSize, E sample, String dataClassName)
Construct a new ObjectArraySerializer. -
Method Summary
Modifier and Type Method Description E[]
deSerialize(byte[] buffer, Pointer pointer, EndianUtil endianUtil)
Deserialize an object of type T.void
serialize(E[] array, byte[] buffer, Pointer pointer, EndianUtil endianUtil)
Serialize an object of type T; not including the prefix byte(s).void
serializeWithPrefix(E[] array, byte[] buffer, Pointer pointer, EndianUtil endianUtil)
Serialize an object of type T including the prefix byte(s).int
size(E[] array)
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).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
- T[]; 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 SerializationExceptionDescription 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
-