Java中 byte[]数组序列化和fastjson序列化区别

本文探讨了Java中对象通过byte数组和fastjson进行序列化的区别。byte数组序列化需要考虑对象的serialVersionUID,而fastjson序列化更为简便。性能测试显示,在大量数据情况下,fastjson在速度上表现出优势。

Java中 byte[]数组序列化和fastjson序列化区别

Java中,对于对象可以通过序列化成byte数组或者序列化成json形式,这里做下两者的对比。

首先看下实现方式:

1 byte数组序列化

这里由两个方法,一个是对象序列化为字节数组,一个是字节数组序列化为对象,这里需要注意的是对象的serialVersionUID 必须设置为一样才能序列化,否则哪怕两个类长得一模一样都会报错。

private static byte[] ObjectToByte(Object obj) {
    byte[] bytes = null;
    try {
        // object to bytearray
        ByteArrayOutputStream bo = new ByteArrayOutputStream();
        ObjectOutputStream oo = new ObjectOutputStream(bo);
        oo.writeObject(obj);


        bytes = bo.toByteArray();


        bo.close();
        oo.close();
    } catch (Exception e) {
        System.out.println("translation" + e.getMessage());
        e.printStackTrace();
    }
    return bytes;
}


/**
 * byte转对象
 * @param bytes
 * @return
 */
private static Object ByteToObject(byte[] bytes) {
    Object obj = null;
    try {
        // bytearray to object
        ByteArrayInputStream bi = new ByteArrayInputStream(bytes);
        ObjectInputStream oi = new ObjectInputStream(bi);


        obj = oi.readObject();
        bi.close();
        oi.close();
    } catch (Exception e) {
        System.out.println("translation" + e.getMessage());
        e.printStackTrace();
    }
    return obj;
}

2 fastjson序列化

这里选择了fastJson来序列化对象,实现方式如下:

public static <T> T get(String data, Class<T> clazz) {
    T body = JSON.parseObject(data, clazz);
    return body;
}


public static String toJson(Object o) {
    return JSONObject.toJSONString(o);
}

fastJson实现方法比较简单。

下面对性能进行了对比:

类别1000次5000次10000次100000次1000000次
byte数组82ms147ms213ms827ms5707ms
fastJson114ms157ms146ms174ms412ms

此数据来自i7 16g内存windows eclipse软件测试得来。

可以看出来在大规模数据的情况下fastJson还是非常快的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值