Protostuff序列化

LiCheng2022年7月12日小于 1 分钟

Protostuff序列化

介绍

使用

<dependencies>
    <dependency>
        <groupId>io.protostuff</groupId>
        <artifactId>protostuff-core</artifactId>
        <version>1.8.0</version>
    </dependency>
    <dependency>
        <groupId>io.protostuff</groupId>
        <artifactId>protostuff-runtime</artifactId>
        <version>1.8.0</version>
    </dependency>
</dependencies>
  • 测试
package com.zkyt;

import cn.hutool.json.JSONUtil;
import io.protostuff.LinkedBuffer;
import io.protostuff.ProtostuffIOUtil;
import io.protostuff.Schema;
import io.protostuff.runtime.RuntimeSchema;
import lombok.Data;

@Data
public class Foo  {
    private String name;
    private Integer id;

    public Foo(String name, int id) {
        this.name = name;
        this.id = id;
    }

    public static void main(String[] args) {
        Foo foo = new Foo("Foo", 1);
        Schema<Foo> schema = RuntimeSchema.getSchema(Foo.class);
        LinkedBuffer buffer = LinkedBuffer.allocate();
        final byte[] protostuff;
        try {
            //解析成字节数组
            protostuff = ProtostuffIOUtil.toByteArray(foo, schema, buffer);
        } finally {
            buffer.clear();
        }
        //性能对比字节数
        System.out.println(protostuff.length);//10
        System.out.println(JSONUtil.toJsonStr(foo).getBytes().length);// 15-30

        //获取对象
        Foo fooParsed = schema.newMessage();
        //将字节的数据合并到对象里面
        ProtostuffIOUtil.mergeFrom(protostuff, fooParsed, schema);
        System.out.println(fooParsed);
    }
}

  • 使用该框架
  • 比直接json字符串转字节,压缩了3倍-1.5倍