首页
/ FusionCache中工厂方法返回可空类型的实践指南

FusionCache中工厂方法返回可空类型的实践指南

2025-06-28 16:48:16作者:魏献源Searcher

背景介绍

在使用FusionCache进行缓存操作时,开发者经常会遇到需要从数据源读取数据并缓存的情况。一个常见的场景是:当缓存未命中时,通过工厂方法从数据库或其他数据源获取数据,然后将结果存入缓存。在这个过程中,如何处理数据源可能返回null值的情况,是一个值得探讨的技术问题。

问题分析

在FusionCache的标准用法中,GetOrSetAsync方法的工厂函数通常被设计为返回非空类型。然而在实际开发中,数据访问层的方法(如readObjectAsync)往往会返回可空类型,这就导致了类型不匹配的问题。

开发者常见的解决方式是使用null宽容运算符(!)强制转换,但这种做法存在潜在风险,因为它绕过了编译器的null检查,可能导致运行时异常。例如:

var item = await readObjectAsync();
return item!; // 潜在风险:如果item为null,将抛出异常

最佳实践解决方案

FusionCache实际上支持工厂方法返回可空类型,只需要在调用GetOrSetAsync时明确指定泛型参数为可空类型即可。这种模式更加安全,也更符合实际开发场景:

var item2 = await _fusionCache.GetOrSetAsync<TItem?>(realKey, OnCallBack);

async Task<TItem?> OnCallBack(FusionCacheFactoryExecutionContext<TItem?> context, CancellationToken token)
{
    var item = await readObjectAsync();
    if(item is null)
    {
        if(context.Options.Duration.TotalSeconds > 60)
            context.Options.Duration = TimeSpan.FromMinutes(1);
    }
    return item; // 无需使用null宽容运算符
}

技术要点解析

  1. 泛型参数声明:通过TItem?明确表示接受可空类型
  2. 上下文匹配:工厂方法的FusionCacheFactoryExecutionContext泛型参数也需要改为TItem?
  3. 时间处理:注意使用TotalSeconds而非Seconds来获取完整的时间跨度

替代方案

如果业务上确实需要保证返回非null值,可以考虑以下模式:

TItem defaultValue = GetDefaultValue(); // 获取业务默认值

var item2 = await _fusionCache.GetOrSetAsync<TItem>(realKey, OnCallBack);

async Task<TItem> OnCallBack(FusionCacheFactoryExecutionContext<TItem> context, CancellationToken token)
{
    var item = await readObjectAsync();
    if(item is null)
    {
        if(context.Options.Duration.TotalSeconds > 60)
            context.Options.Duration = TimeSpan.FromMinutes(1);
    }
    return item ?? defaultValue; // 提供默认值而非null
}

总结

在FusionCache中使用工厂方法时,正确处理可空返回值是保证代码健壮性的关键。通过明确声明可空泛型参数,可以避免不必要的null宽容运算符使用,使代码更加安全可靠。同时,开发者应当根据业务需求,选择最适合的null值处理策略,无论是接受可空结果还是提供默认值替代null。

登录后查看全文

项目优选

收起
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
51
15
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
116
200
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
503
398
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
62
144
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
295
1.01 K
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
97
251
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
381
37
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
692
91
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
97
74
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
357
341