1、引入包
<!--msgpack依賴--> <dependency> <groupId>org.msgpack</groupId> <artifactId>msgpack</artifactId> <version>0.6.11</version> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.12.6</version> <scope>provided</scope> </dependency>
2、創建實體類
注意,必須實現:Serializable,和@Message注解
package com.cyb.vo; import lombok.Data; import org.msgpack.annotation.Message; import java.io.Serializable; @Message @Data public class Member implements Serializable { private String mid; private String mname; private String mage; }
3、方法使用
package com.cyb.test; import com.cyb.vo.Member; import org.msgpack.MessagePack; import org.msgpack.template.Templates; import java.util.ArrayList; import java.util.List; public class Test01 { public static void main(String[] args) throws Exception { Member member = new Member(); member.setMid("101"); member.setMname("alex"); member.setMage("25"); MessagePack msgPack = new MessagePack(); byte[] data = msgPack.write(member); //將實體類數據轉為Byte字節數組 System.out.println(data.length); //打印字節數組長度 //將實體類數據解析回來 Member member1 = msgPack.read(data, Member.class); System.out.println(member1); //========解析實體類數組============= List<Member> allMemberList = new ArrayList<Member>(); for (int x = 0; x < 5; x++) { Member m = new Member(); m.setMid(x + ""); m.setMname("sasa" + x); m.setMage("18"); allMemberList.add(m); } MessagePack msgPack2 = new MessagePack(); byte[] data2 = msgPack2.write(allMemberList); List<Member> all = msgPack2.read(data2, Templates.tList(msgPack2.lookup(Member.class))); System.out.println(all); } }