.NET 4 ObjectCache – 我们可以陷入“缓存过期”事件吗?
我有一个像这样缓存的简单对象:
_myCache.Add(someKey, someObj, policy);
其中_myCache
被声明为ObjectCache
(但通过DI注入为MemoryCache.Default
), someObj
是我正在添加的对象,而policy
是CacheItemPolicy
。
如果我有这样的CacheItemPolicy
:
var policy = new CacheItemPolicy { Priority = CacheItemPriority.Default, SlidingExpiration = TimeSpan.FromHours(1) };
这意味着它将在1小时后到期。 凉。
但是会发生的事情是,一小时后不幸的第一个用户将不得不等待命中。
有什么方法可以挂钩到“过期”事件/委托并手动刷新缓存?
我看到有一个提到CacheEntryChangeMonitor
但是在我的例子中找不到任何关于如何利用它的有意义的doco /例子。
PS。 我知道我可以使用CacheItemPriority.NotRemovable
并手动过期,但我不能在我当前的例子中这样做,因为缓存的数据有点太复杂(例如,我需要在我的代码中的10个不同位置“无效” )。
有任何想法吗?
CacheItemPolicy
上有一个名为RemovedCallback
的属性,其类型为: CacheEntryRemovedCallback
。 不知道为什么他们没有采用标准的活动路线,但这应该做你需要的。
http://msdn.microsoft.com/en-us/library/system.runtime.caching.cacheitempolicy.removedcallback.aspx
迟到了这个,但我刚刚注意到CacheItemUpdate和CacheItemRemove回调之间的一个有趣的区别。
http://msdn.microsoft.com/en-us/library/system.web.caching.cacheitemupdatereason.aspx
特别是这个评论:
与CacheItemRemovedReason枚举不同,此枚举不包括已删除或未使用的值。 可更新的缓存项不可移除,因此即使需要释放内存,也不会被ASP.NET自动删除。
- 当InstanceContextMode设置为PerSession时,如何为所有客户端运行一次WCF服务构造函数?
- 对于C#中的匹配,Regex实例线程是否安全?
- IEnumerable与IQueryable的业务逻辑或DAL返回类型
- entity framework:路径中的非法字符。 (连接字符串)(MVC3)
- 通过PublicKeyToken防止外部程序集注入
- 在C#/ .NET 4.0中新的NoPIA和Type Equivalencefunction是否意味着不再需要Microsoft.mshtml.dll
- 将动态表格或div内容作为电子邮件正文内容发送
- System.Windows.Shell参考丢失
- Lambda具有嵌套类