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 SerializerDoubleArray extends GroupSerializerObjectArray<double[]> { @Override public void serialize(DataOutput2 out, double[] value) throws IOException { out.packInt(value.length); for (double c : value) { out.writeDouble(c); } } @Override public double[] deserialize(DataInput2 in, int available) throws IOException { final int size = in.unpackInt(); double[] ret = new double[size]; for (int i = 0; i < size; i++) { ret[i] = in.readDouble(); } return ret; } @Override public boolean isTrusted() { return true; } @Override public boolean equals(double[] a1, double[] a2) { return Arrays.equals(a1, a2); } @Override public int hashCode(double[] bytes, int seed) { for (double element : bytes) { long bits = Double.doubleToLongBits(element); seed = (-1640531527) * seed + (int) (bits ^ (bits >>> 32)); } return seed; } @Override public int compare(double[] o1, double[] 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); } }