加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

MessagePack Java Jackson Dataformat - Map 的序列化和反序列化

发布时间:2020-12-15 05:24:25 所属栏目:Java 来源:网络整理
导读:本测试方法,可以在?https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/test/java/com/insight/demo/serialize/MessagePackSerializer.java?中找到。 我们需要定义测试需要的 MAP,定义 Map 的方法你可以在下面的测试程序

本测试方法,可以在?https://github.com/cwiki-us-demo/serialize-deserialize-demo-java/blob/master/src/test/java/com/insight/demo/serialize/MessagePackSerializer.java?中找到。

我们需要定义测试需要的 MAP,定义 Map 的方法你可以在下面的测试程序中找到。

/**
  * SerializationMap
  */
 @Test
 public void testMessagePackSerializationMap() {

     byte[] bytes = new byte[0];
     String uuid_a = UUID.randomUUID().toString();
     String uuid_b = UUID.randomUUID().toString();

     // Instantiate ObjectMapper for MessagePack
     ObjectMapper objectMapper = new ObjectMapper(new MessagePackFactory());

     Map<String,MessageData> map = new HashMap<>();
     MessageData messageData = new MessageData();

     // Element A in MAP
     messageData.setUuid(UUID.randomUUID().toString());
     messageData.setName("CWIKI.US - A");
     map.put(uuid_a,messageData);

     // Element B in MAP
     messageData = new MessageData();
     messageData.setUuid(UUID.randomUUID().toString());
     messageData.setName("CWIKI.US - B");
     map.put(uuid_b,messageData);


     try {
         // Serialize a Java object to byte array
         bytes = objectMapper.writeValueAsBytes(map);
         logger.debug("Length of Bytes: [{}]",bytes.length);

         // Deserialize the byte array to a MAP
         Map<String,MessageData> deserialized = objectMapper.readValue(bytes,new TypeReference<Map<String,MessageData>>() {
         });
         logger.debug("Deserialized MAP Count: [{}]",deserialized.size());
         logger.debug("MAP index 0: [{}]",deserialized.get(uuid_a).getName());

         assertEquals("CWIKI.US - A",deserialized.get(uuid_a).getName());

     } catch (JsonProcessingException ex) {
         logger.error("Serialize Error",ex);
     } catch (IOException e) {
         e.printStackTrace();
     }


 }

https://www.cwiki.us/display/Serialization/MessagePack+Jackson+Dataformat

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读