msgpack java 序列化对象_MessagePack Java 0.6.X List, Map 对象的序列化和反序列化

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

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

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

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

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

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> listTmpl = tList(TString);

Template> mapTmpl = tMap(TString, TString);

//

// Serialization

//

ByteArrayOutputStream out = new ByteArrayOutputStream();

Packer packer = msgpack.createPacker(out);

// Serialize List object

List list = new ArrayList();

list.add("msgpack");

list.add("for");

list.add("java");

packer.write(list); // List object

// Serialize Map object

Map map = new HashMap();

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 dstList = unpacker.read(listTmpl);

// to Map object

Map dstMap = unpacker.read(mapTmpl);

} catch (Exception ex) {

logger.error("MessagePack Serialization And Deserialization error", ex);

}

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值