温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MessagePack Java 0.6.X List, Map 对象的序列化和反序列化

发布时间:2020-03-31 08:00:47 来源:网络 阅读:355 作者:HoneyMoose 栏目:大数据

为了序列化原生的容器对象例如  List 和 Map 对象,你必须使用 Template

Template 对象是 serializer 和 deserializer 的配对。例如,为了序列化一个 List 对象,在 List 对象中 Integer 对象为元素,你可以使用下面的方法来创建一个模板对象(Template object)。

Template listTmpl = Templates.tList(Templates.TInteger);

类 tList, TInteger 是静态方法,字段为 Templates。

一个 List 和 Map 对象的用例如下显示:

本代码可以在 https://github.com/cwiki-us-demo/messagepack-6-demo-java/blob/master/src/test/java/com/insight/demo/msgpack/MessagePack6Template.java 中查看。

package com.insight.demo.msgpack; import org.junit.Test; import org.msgpack.MessagePack; import org.msgpack.packer.Packer; import org.msgpack.template.Template; import org.msgpack.unpacker.Unpacker; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.math.BigInteger; import java.nio.ByteBuffer; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import static org.msgpack.template.Templates.*; /**  * MessagePack6Template  *  * @author yhu  */ public class MessagePack6Template {     final Logger logger = LoggerFactory.getLogger(MessagePack6Template.class);     /**      * Test MessagePack6Template      */     @Test     public void testMessagePack6Template() {         logger.debug("MessagePack6Template for Template");         MessagePack msgpack = new MessagePack();         try {             // Create templates for serializing/deserializing List and Map objects             Template<List<String>> listTmpl = tList(TString);             Template<Map<String, String>> mapTmpl = tMap(TString, TString);             //             // Serialization             //             ByteArrayOutputStream out = new ByteArrayOutputStream();             Packer packer = msgpack.createPacker(out);             // Serialize List object             List<String> list = new ArrayList<String>();             list.add("msgpack");             list.add("for");             list.add("java");             packer.write(list); // List object             // Serialize Map object             Map<String, String> map = new HashMap<String, String>();             map.put("sadayuki", "furuhashi");             map.put("muga", "nishizawa");             packer.write(map); // Map object             //             // Deserialization             //             byte[] bytes = out.toByteArray();             ByteArrayInputStream in = new ByteArrayInputStream(bytes);             Unpacker unpacker = msgpack.createUnpacker(in);             // to List object             List<String> dstList = unpacker.read(listTmpl);             // to Map object             Map<String, String> dstMap = unpacker.read(mapTmpl);         } catch (Exception ex) {             logger.error("MessagePack Serialization And Deserialization error", ex);         }     } }

https://www.cwiki.us/display/Serialization/QuickStart+For+MessagePack+Java+0.6.X


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI