在 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不复杂但容易忽略细节,关键是按需设过期、合理封装访问逻辑、注意对象生命周期。
