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()));