[toc]
MessagePack编解码技术介绍与使用
编解码技术介绍
Java中本身技术序列化技术,即使用ObjectInputStream
和ObjectOutputStream
即可完成对象的序列化和反序列化,目的主要有如下:
对象持久化存储
网络传输
当然,因为最近学习主要是学习Netty,所以这里更多是出于网络传输的目的,所以对于编解码的基本解释,可如下:
编码:将Java对象转化为字节数组或ByteBuffer对象;
解码:将字节数组或ByteBuffer对象转化为Java对象;
当然因为Java序列化技术本身的局限,如不能跨语言、序列化性能低、序列化码流大等问题,所以出现了很多编解码框架,如这里要说明的MessagePack。
MessagePack基本使用
直接给出下面的代码即可了解MessagePack的基本使用方法,不过这里需要说明的是,MessagePack将对象编码后,解码返回的对象是一个List集合,例如将一个pojo对象编码再解码后的结果就是原来pojo对象属性所组成的List列表。
另外,pojo对象一定要加上@Message注解,否则是无法将pojo对象进行编码的。
Demo.java
package cn.xpleaf.msgpack;import java.util.ArrayList;import java.util.List;import org.msgpack.MessagePack;import org.msgpack.template.Templates;import org.msgpack.type.Value;import cn.xpleaf.pojo.User;public class Demo { public static void main(String[] args) throws Exception { // 创建需要编码的对象 List<String> src = new ArrayList<>(); src.add("msgpack"); src.add("kumofs"); src.add("viver"); MessagePack msgpack = new MessagePack(); // 编码操作 byte[] raw = msgpack.write(src); // 使用模板对象进行解码操作 List<String> dst1 = msgpack.read(raw, Templates.tList(Templates.TString)); System.out.println(dst1); // pojo对象编解码 User user = new User(); user.setName("xpleaf"); user.setAge(10); byte[] bytes = msgpack.write(user); Object obj = msgpack.read(bytes); System.out.println(obj); // 解码结果是一个列表["xpleaf",10] }}
User.java
package cn.xpleaf.pojo;import org.msgpack.annotation.Message;@Messagepublic class User { private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } @Override public String toString() { return "User [name=" + name + ", age=" + age + "]"; }}
测试
运行Demo.java,输出结果如下:
[msgpack, kumofs, viver]["xpleaf",10]
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦