Class DoubleVectorSerializer<U extends org.djunits.unit.Unit<U>,S extends org.djunits.value.vdouble.scalar.base.DoubleScalarInterface<U,S>,V extends org.djunits.value.vdouble.vector.base.DoubleVectorInterface<U,S,V>>
- java.lang.Object
-
- org.djutils.serialization.serializers.BasicSerializer<T>
-
- org.djutils.serialization.serializers.ArrayOrMatrixWithUnitSerializer<U,V>
-
- org.djutils.serialization.serializers.DoubleVectorSerializer<U,S,V>
-
- Type Parameters:
U
- the unit typeS
- the scalar typeV
- the vector type
- All Implemented Interfaces:
Serializer<V>
public class DoubleVectorSerializer<U extends org.djunits.unit.Unit<U>,S extends org.djunits.value.vdouble.scalar.base.DoubleScalarInterface<U,S>,V extends org.djunits.value.vdouble.vector.base.DoubleVectorInterface<U,S,V>> extends ArrayOrMatrixWithUnitSerializer<U,V>
(De)serializes a DJUNITS DoubleVector.Copyright (c) 2019-2021 Delft University of Technology, PO Box 5, 2600 AA, Delft, the Netherlands. All rights reserved.
BSD-style license. See DJUNITS License.- Author:
- Alexander Verbraeck
-
-
Constructor Summary
Constructors Constructor Description DoubleVectorSerializer()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description V
deSerialize(byte[] buffer, Pointer pointer, EndianUtil endianUtil)
Deserialize an object of type T.void
serialize(V adv, byte[] buffer, Pointer pointer, EndianUtil endianUtil)
Serialize an object of type T; not including the prefix byte(s).int
size(V adv)
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).-
Methods inherited from class org.djutils.serialization.serializers.ArrayOrMatrixWithUnitSerializer
encodeUnit, getNumberOfDimensions, getUnit, serializeWithPrefix, sizeWithPrefix
-
Methods inherited from class org.djutils.serialization.serializers.BasicSerializer
dataClassName, fieldType, toString
-
-
-
-
Method Detail
-
size
public int size(V adv) throws SerializationException
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:
adv
- T; Instance of the object- Returns:
- int; the number of bytes needed to serialize an object of type T
- Throws:
SerializationException
- when theobject
cannot be serialized
-
serialize
public void serialize(V adv, byte[] buffer, Pointer pointer, EndianUtil endianUtil) throws SerializationException
Serialize an object of type T; not including the prefix byte(s).- Parameters:
adv
- 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
-
deSerialize
public V deSerialize(byte[] buffer, Pointer pointer, EndianUtil endianUtil) throws SerializationException
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
- Throws:
SerializationException
- when the input data cannot be deserialized
-
-