Redis:存储对象的两种方式(序列化和json字符串)
方式一:序列化操作
- public class SerializeUtil {
- /*
- * 序列化
- * */
- public static byte[] serizlize(Object object){
- ObjectOutputStream oos = null;
- ByteArrayOutputStream baos = null;
- try {
- baos = new ByteArrayOutputStream();
- oos = new ObjectOutputStream(baos);
- oos.writeObject(object);
- byte[] bytes = baos.toByteArray();
- return bytes;
- } catch (Exception e) {
- e.printStackTrace();
- }finally {
- try {
- if(baos != null){
- baos.close();
- }
- if (oos != null) {
- oos.close();
- }
- } catch (Exception e2) {
- e2.printStackTrace();
- }
- }
- return null;
- }
- /*
- * 反序列化
- * */
- public static Object deserialize(byte[] bytes){
- ByteArrayInputStream bais = null;
- ObjectInputStream ois = null;
- try{
- bais = new ByteArrayInputStream(bytes);
- ois = new ObjectInputStream(bais);
- return ois.readObject();
- }catch(Exception e){
- e.printStackTrace();
- }finally {
- try {
- } catch (Exception e2) {
- e2.printStackTrace();
- }
- }
- return null;
- }
- }
获取jedis实例
- public class RedisConnection {
- private static String HOST = "127.0.0.1";
- private static int PORT = 6379;
- private static int MAX_ACTIVE = 1024;
- private static int MAX_IDLE = 200;
- private static int MAX_WAIT = 10000;
- private static JedisPool jedisPool = null;
- /*
- * 初始化redis连接池
- * */
- private static void initPool(){
- try {
- JedisPoolConfig config = new JedisPoolConfig();
- config.setMaxTotal(MAX_ACTIVE);//最大连接数
- config.setMaxIdle(MAX_IDLE);//最大空闲连接数
- config.setMaxWaitMillis(MAX_WAIT);//获取可用连接的最大等待时间
- jedisPool = new JedisPool(config, HOST, PORT);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- /*
- * 获取jedis实例
- * */
- public synchronized static Jedis getJedis() {
- try {
- if(jedisPool == null){
- initPool();
- }
- Jedis jedis = jedisPool.getResource();
- jedis.auth("redis");//密码
- return jedis;
- } catch (Exception e) {
- e.printStackTrace();
- return null;
- }
- }
- }
redis操作
- public class RedisOps {
- public static void set(String key,String value){
- Jedis jedis = RedisConnection.getJedis();
- jedis.set(key, value);
- jedis.close();
- }
- public static String get(String key){
- Jedis jedis = RedisConnection.getJedis();
- String value = jedis.get(key);
- jedis.close();
- return value;
- }
- public static void setObject(String key,Object object){
- Jedis jedis = RedisConnection.getJedis();
- jedis.set(key.getBytes(), SerializeUtil.serizlize(object));
- jedis.close();
- }
- public static Object getObject(String key){
- Jedis jedis = RedisConnection.getJedis();
- byte[] bytes = jedis.get(key.getBytes());
- jedis.close();
- return SerializeUtil.deserialize(bytes);
- }
- }
实体类
- public class User implements Serializable{
- private static final long serialVersionUID = -3210884885630038713L;
- private int id;
- private String name;
- public User(){
- }
- public User(int id,String name){
- this.id = id;
- this.name = name;
- }
- //setter和getter方法
- }
测试用例
- public class RedisTest {
- @Test
- public void testString(){
- RedisOps.set("user:1", "sisu");
- String user = RedisOps.get("user:1");
- Assert.assertEquals("sisu", user);
- }
- @Test
- public void testObject(){
- RedisOps.setObject("user:2",new User(2,"lumia"));
- User user = (User)RedisOps.getObject("user:2");
- Assert.assertEquals("lumia", user.getName());
- }
- }
方式二:使用fastjson将对象转为json字符串后存储
- public class RedisOps {
- public static void setJsonString(String key,Object object){
- Jedis jedis = RedisConnection.getJedis();
- jedis.set(key, JSON.toJSONString(object));
- jedis.close();
- }
- public static Object getJsonObject(String key,Class clazz){
- Jedis jedis = RedisConnection.getJedis();
- String value = jedis.get(key);
- jedis.close();
- return JSON.parseObject(value,clazz);
- }
- }
测试:
- @Test
- public void testObject2(){
- RedisOps.setJsonString("user:3", new User(3,"xiaoming"));
- User user = (User)RedisOps.getJsonObject("user:3",User.class);
- Assert.assertEquals("xiaoming", user.getName());
Redis:存储对象的两种方式(序列化和json字符串)的更多相关文章
- Redis 备份数据的两种方式
既然是数据库,那就一定有数据备份方式了,而且 Redis 是内存形式的数据库,更需要数据备份了,要不然断电数据就全都丢失了. Redis 数据备份有两种方式: RDB(数据快照) AOF(记录操作日志 ...
- iOS:创建单例对象的两种方式
单例模式:创建单例对象的两种方式 方式一:iOS4版本之前 static SingleClassManager *singleManager = nil; +(SingleClas ...
- Python与数据库[2] -> 关系对象映射/ORM[2] -> 建立声明层表对象的两种方式
建立声明层表对象的两种方式 在对表对象进行建立的时候,通常有两种方式可以完成,以下是两种方式的建立过程对比 首先导入需要的模块,获取一个声明层 from sqlalchemy.sql.schema i ...
- Java反射02 : Class对象获取的三种方式和通过反射实例化对象的两种方式
1.Class对象获取的三种方式 本文转载自:https://blog.csdn.net/hanchao5272/article/details/79361463 上一章节已经说过,一般情况下,Jav ...
- Redis数据持久化的两种方式RDB和AOF
由于Redis的数据都存放在内存中,如果没有配置持久化,redis重启后数据就全丢失了,于是需要开启redis的持久化功能,将数据保存到磁 盘上,当redis重启后,可以从磁盘中恢复数据.redis提 ...
- Asp.net Web API 返回Json对象的两种方式
这两种方式都是以HttpResponseMessage的形式返回, 方式一:以字符串的形式 var content = new StringContent("{\"FileName ...
- Redis的持久化的两种方式drbd以及aof日志方式
redis的持久化配置: 主要包括两种方式:1.快照 2 日志 来看一下redis的rdb的配置选项和它的工作原理: save 900 1 // 表示的是900s内,有1条写入,则产生快照 save ...
- JS中访问对象的两种方式区别
可以使用下面两种方式访问对象的属性和方法 1.对象名.属性名 对象名.方法名() 2.对象名["属性名"] 对象名["方法名"]() var obj = { n ...
- hibernate载入持久化对象的两种方式——get、load
一.get与load对照 在hibernate中get和load方法是依据id取得持久化对象的两种方法.但在实际使用的过程中总会把两者混淆,不知道什么情况下使用get好,什么时候使用load方法效率更 ...
随机推荐
- WOJ 46 完全背包
高级的暴力,神仙优化…… 首先$O(n^{3})$的$dp$很好想,然后这样可以$O(1)$地回答询问. 考虑到所有物品的体积是一个连续的区间,所以说我们可以合并一些物品来达到预处理时间均摊的效果. ...
- Git 之 github分享代码
作为一个技术人员还是脱离不了屌丝的本质,所以每天都是逛逛github,看看别人有什么好的项目,自己可以给他挑挑bug也可以提供自己的水平,但是别人不那怎么才能给别人贡献代码呢?那就是fork了.... ...
- 通配符的匹配很全面, 但无法找到元素 'tx:annotation-driven'
配置Spring时出现如题这个错误,下面是xml的内容 <?xml version="1.0" encoding="UTF-8"?> <bea ...
- jQuery的选择器+实例
返回目录 jQuery的冒号选择器 表单 :input :text :password :radio :checkbox :submit :image :reset :button :file :h ...
- ASP.NET MVC底层原理与框架
前言 鄙人有一毛病,喜欢钻研原理性的东西,感觉只知道怎么用还不太够,更想知道如何实现的以及为什么会这样. 暑假的时候做积分系统是第一次接触MVC,感觉MVC就是一个框架,分为Module ,view和 ...
- java 学习第零篇JDK安装和记事本编辑JAVA(2)
上面说了如何安装JDK那么这把就是来说怎么用记事本编写java 桌面上新建一个记事本 之后编写: public class a{ public static void main(String [ ...
- 【谁知道C#字段为什么用属性封装?】
源地址:https://zhidao.baidu.com/question/1174413218458798139.html 我们知道,类成员包括变量和方法.如果希望其他类能够访问成员变量的值,就必须 ...
- P1452 Beauty Contest 旋转卡壳
\(\color{#0066ff}{题目描述}\) 贝茜在牛的选美比赛中赢得了冠军"牛世界小姐".因此,贝西会参观N(2 < = N < = 50000)个农场来传播善 ...
- Kruskal算法 克鲁斯卡尔
30行 #include <iostream> #include <algorithm> using namespace std; int f[5001],n,m,ans=0, ...
- There is no row in position 0
更改程序池 管道模式 ---->经典 常见设置问题: 32位启用