当前位置: 首页 > article >正文

redis中序列化后的对象后当如何修改

redis中序列化

      • Redis 中存储的序列化对象是不可变
      • 需要频繁修改对象属性, 我存储对象为hash结构如何?
      • 总结

君问归期未有期,巴山夜雨涨秋池。——唐代李商隐《夜雨寄北》

Redis 中存储的序列化对象是不可变

在 Redis 中存储的序列化对象是不可变的,因为它们被序列化为字节数组并存储在 Redis 中,无法直接访问对象属性。如果您想修改对象属性,您需要将对象反序列化为一个 Java 对象,然后修改属性值,再将修改后的对象重新序列化并存储回 Redis 中。

以下是一个示例代码,它从 Redis 中获取序列化对象、将其反序列化为一个 Java 对象、修改对象属性值、然后再次将修改后的对象序列化并存储回 Redis 中:

@Autowired
private RedisTemplate<String, Object> redisTemplate;

public void updateProperty(String key) throws IOException {
    byte[] bytes = redisTemplate.opsForValue().get(key);
    if (bytes == null) {
        throw new IllegalArgumentException("Key not found in Redis");
    }

    MyObject myObject = deserialize(bytes); // 将字节数组反序列化为 Java 对象
    myObject.setIntProperty(myObject.getIntProperty() + 1); // 修改对象属性值
    byte[] updatedBytes = serialize(myObject); // 将修改后的对象序列化为字节数组
    redisTemplate.opsForValue().set(key, updatedBytes); // 将修改后的对象存储回 Redis
}

private MyObject deserialize(byte[] bytes) throws IOException, ClassNotFoundException {
    ByteArrayInputStream bis = new ByteArrayInputStream(bytes);
    ObjectInputStream ois = new ObjectInputStream(bis);
    return (MyObject) ois.readObject();
}

private byte[] serialize(MyObject myObject) throws IOException {
    ByteArrayOutputStream bos = new ByteArrayOutputStream();
    ObjectOutputStream oos = new ObjectOutputStream(bos);
    oos.writeObject(myObject);
    return bos.toByteArray();
}

在这个示例中,我们首先使用 RedisTemplateopsForValue() 方法获取 ValueOperations 对象,然后使用 get() 方法获取 Redis 中存储的序列化对象的字节数组。然后,我们使用 deserialize() 方法将字节数组反序列化为 Java 对象,修改对象属性值,再使用 serialize() 方法将修改后的对象序列化为字节数组,最后将修改后的对象存储回 Redis 中。

需要注意的是,对象的反序列化和序列化是一种昂贵的操作,它需要将对象从字节数组转换为 Java 对象,或将 Java 对象转换为字节数组。如果您需要频繁修改对象属性,建议将对象存储为 Redis 基本数据类型,如字符串或整数,避免了反序列化和序列化的开销。

需要频繁修改对象属性, 我存储对象为hash结构如何?

需要频繁地修改对象属性,将对象存储为 Redis 的 Hash 结构可能是更好的选择。Redis 的 Hash 结构是一个键值对集合,可以存储多个字段和值,并提供了快速访问和修改单个字段的功能。

以下是一个示例代码,它将对象存储为 Redis 的 Hash 结构,并提供了一些方法来访问和修改对象的属性:

@Autowired
private RedisTemplate<String, Object> redisTemplate;

public void saveMyObject(MyObject myObject) {
    String key = "myObject:" + myObject.getId();
    Map<String, Object> map = new HashMap<>();
    map.put("intProperty", myObject.getIntProperty());
    map.put("stringProperty", myObject.getStringProperty());
    redisTemplate.opsForHash().putAll(key, map);
}

public MyObject getMyObject(int id) {
    String key = "myObject:" + id;
    Map<Object, Object> map = redisTemplate.opsForHash().entries(key);
    MyObject myObject = new MyObject();
    myObject.setId(id);
    myObject.setIntProperty((Integer) map.get("intProperty"));
    myObject.setStringProperty((String) map.get("stringProperty"));
    return myObject;
}

public void updateIntProperty(int id, int newValue) {
    String key = "myObject:" + id;
    redisTemplate.opsForHash().put(key, "intProperty", newValue);
}

public void updateStringProperty(int id, String newValue) {
    String key = "myObject:" + id;
    redisTemplate.opsForHash().put(key, "stringProperty", newValue);
}

在这个示例中,我们将对象存储为 Redis 的 Hash 结构,使用对象的 ID 作为键,将对象的属性名和属性值作为字段和值存储在 Hash 结构中。saveMyObject() 方法存储对象,getMyObject() 方法获取对象,updateIntProperty()updateStringProperty() 方法分别更新整型和字符串类型的属性。

总结

需要注意的是,存储对象为 Hash 结构需要将对象属性名和属性值都转换为字符串类型。在获取对象时,我们需要将属性值转换回原始类型。此外,如果您的对象属性很多,存储为 Hash 结构可能会占用大量的内存,因此请确保仅存储必要的属性。

不需要频繁修改的属性存储为 Redis 字符串或其他合适的 Redis 数据结构

最后,您需要根据您的应用程序需求来选择适合的 Redis 数据结构和存储方式,以及确保数据访问和修改的原子性和一致性


http://www.kler.cn/a/5618.html

相关文章:

  • 如何看待Akamai 退出中国市场进行转型?
  • 计算机网络(二)——物理层和数据链路层
  • 【AI日记】25.01.11 Weights Biases | AI 笔记 notion
  • 一分钟学会文心一言API如何接入,文心一言API接入教程
  • android 官网刷机和线刷
  • 【权限管理】CAS(Central Authentication Service)
  • 实验三Numpy知识点总结
  • java高级工程师_____拼多多电商部二面试题集锦
  • 数据库原理及应用(六)——视图和子查询
  • 分享我通过 API 赚钱的思路
  • 【安卓开发】显示手机信息的APP
  • python get方法及常用的代码
  • 37了解高可用技术方案,如冗余、容灾
  • 【Deepstream学习】 TX1模块中C++ Sample application 2详细测试讲解
  • IP协议以及相关技术
  • 【致敬嵌入式攻城狮第2期活动预热征文】 [深入理解SSD 20] 话说固态硬盘里的HMB
  • spark通过connector的方式读写starrocks
  • Java连接SqlServer错误
  • 每日学术速递3.27
  • 学习node之——MySQL的安装和基本使用
  • 重构类关系-Extract Interface提炼接口八
  • 【华为】组播IGMP基本原理(5月份将再次更新,这是以前的笔记 还存在些许问题)
  • 异想天开!没有CPU的操作系统
  • c#第二次作业
  • 【Linux内存管理概述】
  • uni-app--》uni-app的生命周期讲解