C#中使用MemoryCache需通过Microsoft.Extensions.Caching.Memory实现,支持线程安全、过期策略与依赖项;ASP.NET Core内置注册AddMemoryCache(),其他项目需安装NuGet包并推荐依赖注入;存取用Set/TryGetValue或GetOrCreate,支持绝对/滑动过期、优先级和取消令牌;注意对象线程安全、不可变性、内存占用及进程内限制。

在 C# 中使用 MemoryCache 实现内存缓存,核心是借助 Microsoft.Extensions.Caching.Memory 命名空间下的 IMemoryCache 接口和默认实现类。它轻量、线程安全、支持过期策略和依赖项,适合 ASP.NET Core 应用或普通 .NET 项目(需安装 NuGet 包)。
引入依赖和注册服务
如果是 ASP.NET Core 项目,IMemoryCache 已内置,只需在 Program.cs 或 Startup.cs 中注册:
- 在
Program.cs(.NET 6+)中调用builder.Services.AddMemoryCache(); - 若为 .NET Framework 或控制台项目,需手动安装 NuGet 包:
Microsoft.Extensions.Caching.Memory - 然后通过
new MemoryCache(new MemoryCacheOptions())创建实例(不推荐直接 new,建议依赖注入)
在类中注入并使用缓存
在需要缓存的类(如 Controller、Service)构造函数中注入 IMemoryCache:
private readonly IMemoryCache _cache;public MyService(IMemoryCache cache) => _cache = cache;- 存值:用
_cache.Set("key", value, TimeSpan.FromMinutes(10)); - 取值:用
_cache.TryGetValue("key", out var result)(返回 bool,成功则 result 有值) - 推荐用
GetOrCreate方法避免重复计算,例如:_cache.GetOrCreate("user_123", entry => { entry.AbsoluteExpirationRelativeToNow = TimeSpan.FromMinutes(5); return LoadUserFromDb(123); });
设置缓存过期与优先级
MemoryCache 支持多种过期方式和清理控制:
-
绝对过期:指定固定过期时间,如
entry.AbsoluteExpiration = DateTimeOffset.Now.AddSeconds(30); -
滑动过期:每次访问重置计时器,适合活跃数据,如
entry.SlidingExpiration = TimeSpan.FromMinutes(2); -
缓存优先级:内存紧张时低优先级项更早被移除,如
entry.Priority = CacheItemPriority.Low; -
取消令牌:可绑定
CancellationToken实现主动失效,比如监听配置变更
注意事项和常见问题
实际使用中容易忽略但关键的点:
- 缓存对象必须是线程安全可读写的;如果存的是 List 或 Dictionary,外部修改会影响缓存内容,建议存不可变对象或深拷贝
-
IMemoryCache是进程内缓存,不跨应用实例,集群部署需搭配 Redis 等分布式缓存 - 避免缓存大对象(如整个文件流、大集合),会快速消耗内存;可考虑分页缓存或压缩
- 调试时可通过
_cache.Count查看当前缓存项数量(仅限MemoryCache实例,接口无此属性)
基本上就这些。用好 IMemoryCache 不复杂但容易忽略细节,关键是按需设过期、合理封装访问逻辑、注意对象生命周期。










