使用Lambda表达式与回调函数简化缓存操作

简介: 1. 缓存操作流程 对一些写低频,读高频的数据操作我们经常需要用到缓存,通常的缓存操作流程如下: 2. 通常的缓存处理方式 通常我们对上面流程的实现,伪代码如下: public Object getObject(String key) { //1.

1. 缓存操作流程

对一些写低频,读高频的数据操作我们经常需要用到缓存,通常的缓存操作流程如下:

2. 通常的缓存处理方式

通常我们对上面流程的实现,伪代码如下:

public Object getObject(String key) {
    //1. 尝试从缓存读取
    Object obj = readFromCache(key);
    //缓存命中直接返回
    if (obj != null) {
       return obj;
    }

    //2.如果缓存未命中,读数据库
    obj = readFromDB();

    //3. 回写入缓存,并返回
    saveToCache(key,obj);
    return obj;
}

 

对于不同缓存的处理上面步骤1、3是重复的,步骤2是取决于缓存内容变化的,我们无法使用普通方法将上面的流程提取出一个工具函数,而不得不在每一次缓存操作时重复上面步骤1、3的代码。

3. 使用Lambda表达式与回调函数简化缓存操作

这种场景可以利用回调函数的方式将步骤2做为回调函数参数传入,即可将步骤1、3提取成一个工具函数消除这部分重复,并利用Lambda表达式将整个缓存操作简化到一行代码。

这里我使用jdk8自带的java.util.function.Supplier 类做为回调接口类(较低jdk版本的话也可以自己写一个类似接口),利用该类实现java的回调函数,在这个接口类函数实现中进行读DB操作。

利用回调函数方式完成的缓存操作工具类伪代码如下:

public Object getObjectUtil(String key, Supplier<T> supplier) {
    //1. 尝试从缓存读取
    Object obj = readFromCache(key);
    if (obj == null) {
        //2.如果缓存未命中,调用回调函数读数据库
        obj = supplier.get();
        //3. 回写入缓存,并返回
        saveToCache(key,obj);
    }

    return obj;
}

 

通过上面的工具类,进行缓存操作时,我们只需要关心读DB的回调函数接口实现,不需要重复手动判断缓存是否存在等操作。

利用上面的工具类进行缓存操作伪代码如下:

public Object getObject() {
   return getObjectUtil("key",new Supplier() {
        @Override
        public SerializeObject get() {
             return readFromDB();
        }
   });
}

//使用Lambda表达式简化语法:
public Object getObject() {
   return getObjectUtil("key",() -> readFromDB());
}

 

这样,利用Lambda表达式以及回调函数的方式,我们增加一个业务的缓存操作只需要一行代码即可实现。

 

目录
相关文章
|
7月前
|
存储 缓存 NoSQL
【Go语言专栏】Go语言中的Redis操作与缓存应用
【4月更文挑战第30天】本文探讨了在Go语言中使用Redis进行操作和缓存应用的方法。文章介绍了Redis作为高性能键值存储系统,用于提升应用性能。推荐使用`go-redis/redis`库,示例代码展示了连接、设置、获取和删除键值对的基本操作。文章还详细阐述了缓存应用的步骤及常见缓存策略,包括缓存穿透、缓存击穿和缓存雪崩的解决方案。利用Redis和合适策略可有效优化应用性能。
155 0
|
5月前
|
缓存 NoSQL API
分享大厂对于缓存操作的封装
作者shigen分享了关于Redis缓存的封装,以避免常见问题如穿透、击穿、雪崩。封装包括四个文件:CacheEnum、CacheLoader、CacheService和CacheServiceImpl。CacheEnum用于统一管理缓存名和过期时间,CacheService定义缓存操作接口,CacheServiceImpl是实现类,使用Semaphore解决缓存击穿问题。
55 1
分享大厂对于缓存操作的封装
|
5月前
|
存储 算法 缓存
高并发架构设计三大利器:缓存、限流和降级问题之使用RateLimiter来限制操作的频率问题如何解决
高并发架构设计三大利器:缓存、限流和降级问题之使用RateLimiter来限制操作的频率问题如何解决
|
6月前
|
缓存 分布式计算 关系型数据库
数据管理DMS操作报错合集之当进行RDS实例的可用区迁移时,提示“缓存清理”是什么意思
数据管理DMS(Data Management Service)是阿里云提供的数据库管理和运维服务,它支持多种数据库类型,包括RDS、PolarDB、MongoDB等。在使用DMS进行数据库操作时,可能会遇到各种报错情况。以下是一些常见的DMS操作报错及其可能的原因与解决措施的合集。
114 3
|
6月前
|
缓存 运维 Devops
阿里云云效操作报错合集之在构建过程中,Docker尝试从缓存中获取某个文件(或计算缓存键)时遇到了问题,该如何处理
本合集将整理呈现用户在使用过程中遇到的报错及其对应的解决办法,包括但不限于账户权限设置错误、项目配置不正确、代码提交冲突、构建任务执行失败、测试环境异常、需求流转阻塞等问题。阿里云云效是一站式企业级研发协同和DevOps平台,为企业提供从需求规划、开发、测试、发布到运维、运营的全流程端到端服务和工具支撑,致力于提升企业的研发效能和创新能力。
|
7月前
|
缓存 NoSQL 数据库
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
[Redis]——数据一致性,先操作数据库,还是先更新缓存?
164 0
|
7月前
|
存储 缓存 Java
java如何实现一个LRU(最近最少使用)缓存? 要求:设计一个LRU缓存,支持get和put操作。当缓存满时,需要淘汰最近最少使用的元素。要求使用双向链表+哈希表的数据结构来实现,并保证get和put操作的时间复杂度为O(1)。
java如何实现一个LRU(最近最少使用)缓存? 要求:设计一个LRU缓存,支持get和put操作。当缓存满时,需要淘汰最近最少使用的元素。要求使用双向链表+哈希表的数据结构来实现,并保证get和put操作的时间复杂度为O(1)。
72 1
|
7月前
|
存储 缓存 算法
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
数据结构与算法面试题:实现一个 LRU 缓存,支持如下操作:获取值、更新值、删除键值对和插入键值对
80 0
|
canal 缓存 负载均衡
应用多级缓存模式支撑海量数据的读操作
应用多级缓存模式支撑海量数据的读操作
256 0
应用多级缓存模式支撑海量数据的读操作