Я кодирую сложную структуру карты с массивами двойных значений. Высокая точность не важна, а размер вывода важен, поэтому я пытаюсь заставить инструмент JSON (в данном случае Джексон) сериализовать двойные значения с использованием предоставленного DecimalFormat.
Ниже приведен мой лучший вариант, но он терпит неудачу, поскольку сериализатор не выбирается средством сопоставления объектов для кодирования массива:
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 ));
}
}
Результат:
{"тест":[1.1111111111,1.315143204964E12}
Что я искал:
{"тест":[1.32E12, 1.11E0]}
Любые идеи?
Кроме того, мне не нравится генерировать строку и записывать ее как необработанную - могу ли я для этого передать StringBuffer в DecimalFormat?
Спасибо