序列化帮助类

想要将实体对象存放在redis中但是redis中数据只能是byte[]和string 所以写了一个序列化实现类,使用protostuff来对对象进行序列化,下面是实现:

package org.wkframework.util.serialize;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.log4j.Logger;

import com.dyuproject.protostuff.LinkedBuffer;
import com.dyuproject.protostuff.ProtostuffIOUtil;
import com.dyuproject.protostuff.Schema;
import com.dyuproject.protostuff.runtime.DefaultIdStrategy;
import com.dyuproject.protostuff.runtime.RuntimeSchema;

/**
 * 序列化对象帮助类
 * 
 * @date 2016年12月29日 下午5:43:29
 */
public class ProtostuffUtil {
    private static final Logger log = Logger.getLogger(ProtostuffUtil.class);

    private static Map<Class<?>, Schema<?>> cacheShema = new HashMap<Class<?>, Schema<?>>();

    @SuppressWarnings("unchecked")
    private static <T> Schema<T> getSchema(Class<T> clazz) {
        Schema<T> schema = (Schema<T>) cacheShema.get(clazz);
        if (schema == null) {
            synchronized (Schema.class) {
                if (schema == null) {
                    schema = RuntimeSchema.getSchema(clazz,
                            new DefaultIdStrategy());
                    cacheShema.put(clazz, schema);
                }
            }
        }
        return schema;
    }

    /**
     * 序列化对象<T>
     * 
     * @param obj
     * @return
     */
    @SuppressWarnings("unchecked")
    public static <T> byte[] ObjeSerialize(T obj) {
        if (obj == null) {
            throw new RuntimeException("序列化对象(" + obj + ")为空!");
        }
        Schema<T> schema = (Schema<T>) getSchema(obj.getClass());
        LinkedBuffer buffer = LinkedBuffer
                .allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE);
        try {
            return ProtostuffIOUtil.toByteArray(obj, schema, buffer);
        } catch (Exception e) {
            log.error("序列化对象出错");
            throw new RuntimeException("序列化对象(" + obj + ")出错!");
        } finally {
            buffer.clear();
        }
    }

    /**
     * 反序列化对象<T>
     * 
     * @param objByte
     * @param clazz
     * @return
     */
    public static <T> T deserialize(byte[] objByte, Class<T> clazz) {
        if (objByte == null || objByte.length == 0) {
            throw new RuntimeException("反序列化对象发生异常,byte为空");
        }
        T instance = null;
        try {
            instance = clazz.newInstance();
            Schema<T> schema = getSchema(clazz);
            ProtostuffIOUtil.mergeFrom(objByte, instance, schema);
        } catch (InstantiationException | IllegalAccessException e) {
            log.error("反序列化对象出错");
            throw new RuntimeException("序列化对象(" + clazz.getName() + ")出错!");
        }
        return instance;
    }

    /**
     * 序列化list<T>对象
     * 
     * @param list
     * @return
     */
    @SuppressWarnings("unchecked")
    public static <T> byte[] serializeList(List<T> list) {
        if (list == null || list.isEmpty()) {
            throw new RuntimeException("序列化对象列表 list发生异常,list对象为空或里面没有数据!");
        }
        Schema<T> schema = (Schema<T>) getSchema(list.get(0).getClass());
        LinkedBuffer buffer = LinkedBuffer
                .allocate(LinkedBuffer.DEFAULT_BUFFER_SIZE);
        byte[] protostuff = null;
        ByteArrayOutputStream bos = null;
        try {
            bos = new ByteArrayOutputStream();
            ProtostuffIOUtil.writeListTo(bos, list, schema, buffer);
            protostuff = bos.toByteArray();
        } catch (Exception e) {
            log.error("序列化list<T>对象出错");
            throw new RuntimeException("序列化对象列表 list发生异常!", e);
        } finally {
            try {
                if (bos != null) {
                    bos.close();
                }
            } catch (IOException e) {
                e.printStackTrace();
            }
            buffer.clear();
        }
        return protostuff;
    }

    /**
     * 反序列化list<T>
     * 
     * @param listByte
     * @param clazz
     * @return
     */
    public static <T> List<T> deserializeList(byte[] listByte, Class<T> clazz) {
        if (listByte == null || listByte.length == 0) {
            throw new RuntimeException("反序列化list对象发生异常,byte为空");
        }
        Schema<T> schema = (Schema<T>) getSchema(clazz);
        List<T> result = null;
        ByteArrayInputStream in = null;
        try {
            in = new ByteArrayInputStream(listByte);
            result = ProtostuffIOUtil.parseListFrom(in, schema);
        } catch (Exception e) {
            log.error("反序列化list<T>对象出错");
            throw new RuntimeException("反序列化对象列表 list发生异常!", e);
        } finally {
            try {
                in.close();
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        return result;
    }
}

所需jar包:
1. protostuff-api-1.0.7.jar
2. protostuff-core-1.0.7.jar
3. protostuff-runtime-1.0.7.jar
4. protostuff-uberjar-1.0.5.jar

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值