1. 程式人生 > >MessagePack編解碼技術介紹與使用

MessagePack編解碼技術介紹與使用

read 直接 except arr temp 使用 需要 持久 進行

[toc]


MessagePack編解碼技術介紹與使用

編解碼技術介紹

Java中本身技術序列化技術,即使用ObjectInputStreamObjectOutputStream即可完成對象的序列化和反序列化,目的主要有如下:

  • 對象持久化存儲
  • 網絡傳輸

當然,因為最近學習主要是學習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編解碼技術介紹與使用