MessagePack編解碼技術介紹與使用
阿新 • • 發佈:2018-02-15
read 直接 except arr temp 使用 需要 持久 進行 [toc]
MessagePack編解碼技術介紹與使用
編解碼技術介紹
Java中本身技術序列化技術,即使用ObjectInputStream
和ObjectOutputStream
即可完成對象的序列化和反序列化,目的主要有如下:
- 對象持久化存儲
- 網絡傳輸
當然,因為最近學習主要是學習Netty,所以這裏更多是出於網絡傳輸的目的,所以對於編解碼的基本解釋,可如下:
- 編碼:將Java對象轉化為字節數組或ByteBuffer對象;
- 解碼:將字節數組或ByteBuffer對象轉化為Java對象;
當然因為Java序列化技術本身的局限,如不能跨語言、序列化性能低、序列化碼流大等問題,所以出現了很多編解碼框架,如這裏要說明的MessagePack。
MessagePack基本使用
直接給出下面的代碼即可了解MessagePack的基本使用方法,不過這裏需要說明的是,MessagePack將對象編碼後,解碼返回的對象是一個List集合,例如將一個pojo對象編碼再解碼後的結果就是原來pojo對象屬性所組成的List列表。
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; @Message public 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]
MessagePack編解碼技術介紹與使用