浅沫记忆 发表于 2021-9-17 22:39:56

详解Java在redis中进行对象的缓存

这篇文章主要介绍了Java在redis中进行对象的缓存,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
java在redis中进行对象的缓存一般有两种方法,这里介绍序列化的方法,个人感觉比较方便,不需要转来转去。
一、首先,在存储的对象上实现序列化的接口


package com.cy.example.entity.system;

import java.util.list;

import com.baomidou.mybatisplus.annotations.tablefield;
import com.baomidou.mybatisplus.annotations.tablename;
import com.cy.example.entity.superentity;

@tablename("users")
public class sysuserentity extends superentity<sysuserentity> {

/**
* 序列化
*/
private static final long serialversionuid = -2967710007706812401l;

private string c_username;

private string c_pwd;

private string c_phone;

private string c_email;

private string n_age;

private string n_sex;

private string n_status;

private sysdepartmententity n_departmentid;

@tablefield(exist = false)
private list<sysroleentity> rolelist;// 一个用户具有多个角色

private sysuserentity n_superior;

//省略getter、setter
}
二、进行存储的编写


// 存储对象
public void setobject(string key, object obj) {
jedis jedis = null;
try {
   jedis = pool.getresource();
   jedis.set(key.getbytes(), serializeutil.serialize(obj));
} catch (exception e) {
   logger.info("缓存服务器连接异常!");
   e.printstacktrace();
} finally {
   // 返还到连接池
   jedis.close();
}
}
三、获取存储的对象


// 获取对象
public object getobject(string key) {

byte[] obj = null;
jedis jedis = null;
try {
   jedis = pool.getresource();
   obj = jedis.get(key.getbytes());
} catch (exception e) {
   logger.info("缓存服务器连接异常!");
   e.printstacktrace();
} finally {
   // 返还到连接池
   jedis.close();
}
return serializeutil.unserialize(obj);
}
可以看到,redis中存储的是序列化之后的对象

以上所述是小编给大家介绍的java在redis中进行对象的缓存详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对CodeAE代码之家网站的支持!
原文链接:https://blog.csdn.net/qq_20989105/article/details/79173618

http://www.zzvips.com/article/178574.html
页: [1]
查看完整版本: 详解Java在redis中进行对象的缓存