除此之外,我们还有一种比较常见的超期策略:按访问频度决定超期。例如,如果我们设置如下超期策略:SlidingExpiration = TimeSpan.FromSeconds(3)。它表示当对象3秒钟内没有得到访问时,就会过期。相对的,如果对象一直被访问,则不会过期。这两个策略并不能同时使用。所以说上面代码中我已注释。
CacheItemPolicy也可以制定UpdateCallback和RemovedCallback,方便我们记日志或执行一些处理操作,非常方便。
ChangeMonitor
虽然前面列举的过期策略是非常常用的策略,能满足我们大多数时候的需求。但是有的时候,过期策略并不能简单的按照时间来判断。例如,我Cache的内容是从一个文本文件中读取的,此时过期的条件则是文件内容是否发生变化:当文件没有发生变更时,直接返回Cache内容,当问及发生变更时,Cache内容超期,需要重新读取文件。这个时候就需要用到ChangeMonitor来实现更为高级的超期判断了。
由于系统已经提供了文件变化的ChangeMonitor——HostFileChangeMonitor,这里就不用自己实现了,直接使用即可。
public string GetValue()
{
var content = cache[CacheKey] as string;
if(content == null)
{
Console.WriteLine("第二种过期方式");
var file = "C:UsersAdministratorDesktoptest.txt";
CacheItemPolicy policy = new CacheItemPolicy();
policy.ChangeMonitors.Add(new HostFileChangeMonitor(new List<string> { file }));
content = File.ReadAllText(file, Encoding.Default); //Encoding.Default用于解决乱码问题
//StreamReader sr = new StreamReader(file, Encoding.Default);
//content = sr.ReadToEnd();
//sr.Close();
//第二种读取方式
cache.Set(cacheKey, content, policy);
}
else
{
Console.WriteLine("Get cached item");
}
return content;
}
这个例子还是比较简单的,对于那些没有自定义的策略,则需要我们实现自己的ChangeMonitor。下次有时间在写篇文章更深入的介绍一下吧。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易采站长站。








