Redis应用中的对象序列化

来源:互联网 发布:加缪手记淘宝 编辑:程序博客网 时间:2024/06/08 08:41
Redis 缓存对象时需要将其序列化,而何为序列化,实际上就是将对象以字节形式存储。这样,不管对象的属性是字符串、整型还是图片、视频等二进制类型,都可以将其保存在字节数组中。对象序列化后便可以持久化保存或网络传输。需要还原对象时,只需将字节数组再反序列化即可。

java中序列化和反序列化方法:

public class SerializeUtil {
  // 序列化对象
  public static byte[] serialize(Object obj) throws IOException {
    ByteArrayOutputStream buf = new ByteArrayOutputStream();
    ObjectOutputStream out = new ObjectOutputStream(buf);
    out.writeObject(obj);
    return buf.toByteArray();
  }
  // 反序列化对象
  public static Object deserialize(byte[] bytes) throws 
        ClassNotFoundException, IOException{
    ObjectInputStream in = new ObjectInputStream(
    new ByteArrayInputStream(bytes));
    return in.readObject();
  }
}

Redis中缓存对象的方法:

// 缓存对象, 生存时间为 H 小时
jedis.setex(key.getBytes(), 3600*H, SerializeUtil.serialize(obj));

// 从缓存中取出对象
obj = (目标类型)SerializeUtil.deserialize(jedis.get(key.getByets()));










0 0
原创粉丝点击