package org.mapdb.serializer; import org.mapdb.DataInput2; import org.mapdb.DataOutput2; import org.mapdb.Serializer; import java.io.IOException; import java.util.Arrays; /** * Created by jan on 2/28/16. */ public class SerializerFloatArray extends GroupSerializerObjectArray<float[]> { @Override public void serialize(DataOutput2 out, float[] value) throws IOException { out.packInt(value.length); for (float v : value) { out.writeFloat(v); } } @Override public float[] deserialize(DataInput2 in, int available) throws IOException { float[] ret = new float[in.unpackInt()]; for (int i = 0; i < ret.length; i++) { ret[i] = in.readFloat(); } return ret; } @Override public boolean isTrusted() { return true; } @Override public boolean equals(float[] a1, float[] a2) { return Arrays.equals(a1, a2); } @Override public int hashCode(float[] floats, int seed) { for (float element : floats) seed = (-1640531527) * seed + Float.floatToIntBits(element); return seed; } @Override public int compare(float[] o1, float[] o2) { if (o1 == o2) return 0; final int len = Math.min(o1.length, o2.length); for (int i = 0; i < len; i++) { if (o1[i] == o2[i]) continue; if (o1[i] > o2[i]) return 1; return -1; } return SerializerUtils.compareInt(o1.length, o2.length); } }