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

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

2025-06-28 09:54:40作者:魏献源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。

登录后查看全文

项目优选

收起
kernelkernel
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
471
465
kernelkernel
deepin linux kernel
C
32
16
atomcodeatomcode
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get Started
Rust
2.09 K
218
ops-nnops-nn
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
700
1.4 K
docsdocs
暂无描述
Dockerfile
780
5.08 K
pytorchpytorch
Ascend Extension for PyTorch
Python
758
968
flutter_flutterflutter_flutter
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
ops-transformerops-transformer
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
880
2.03 K
mindquantummindquantum
MindQuantum is a general software library supporting the development of applications for quantum computation.
Python
183
112
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.11 K
682