Estoy codificando una estructura de mapa compleja con matrices de valores dobles. La alta precisión no es importante y el tamaño de salida es, por lo que estoy tratando de obtener la herramienta JSON (Jackson en este caso) para serializar los valores dobles utilizando un DecimalFormat proporcionado.codificación jackson - json de dobles con precisión controlada
La siguiente es mi mejor tiro, pero esto no funciona como el serializador no es recogido por el mapeador objeto a codificar la matriz:
class MyTest
{
public class MyDoubleSerializer extends JsonSerializer<double[]>
{
public void serialize(double[] value, JsonGenerator jgen, SerializerProvider provider) throws IOException, JsonProcessingException
{
for (double d : value)
{
jgen.writeStartArray();
jgen.writeRaw(df.format(d));
jgen.writeEndArray();
}
}
}
@Test
public void test1() throws Exception
{
ObjectMapper mapper = new ObjectMapper();
SimpleModule module = new SimpleModule("MyModule", new Version(0, 1, 0, "alpha"));
module.addSerializer(double[].class, new MyDoubleSerializer());
mapper.registerModule(module);
Map<String, Object> data = new HashMap<String, Object>();
double[] doubleList = { 1.1111111111D, (double) (System.currentTimeMillis()) };
data.put("test", doubleList);
System.out.print(mapper.writeValueAsString(data));
}
}
La salida es:
{ "prueba" : [1.1111111111,1.315143204964E12}
lo que estaba buscando:
{ "prueba": [1.32E12, 1.11E0]}
¿Alguna idea?
Además, no me gusta tener que generar un String y escribir es tan crudo, ¿podría alimentar un StringBuffer en DecimalFormat para hacer esto?
Gracias