.NET 4.0中新增了一個System.Runtime.Caching的名字空間,它提供了一系列可擴充的Cache架構,本文就簡單的介紹一下如何使用它給程式添加Cache。
一個Cache架構主要包括三個部分:ObjectCache、CacheItemPolicy、ChangeMonitor。
ObjectCache表示一個CachePool,它提供了Cache對象的添加、擷取、更新等介面,是Cache架構的主體。它是一個抽象類別,並且系統給了一個常用的實現——MemoryCache。
CacheItemPolicy則表示Cache到期策略,例如儲存一定時間後到期。它也經常和ChangeMonitor一起使用,以實現更複雜的策略。
ChangeMonitor則主要負責CachePool對象的狀態維護,判斷對象是否需要更新。它也是一個抽象類別,系統也提供了幾個常見的實現:CacheEntryChangeMonitor、FileChangeMonitor、HostFileChangeMonitor、SqlChangeMonitor。
ObjectCache表示一個CachePool,它提供了Cache對象的添加、擷取、更新等介面,是Cache架構的主體。它是一個抽象類別,並且系統給了一個常用的實現——MemoryCache。
CacheItemPolicy則表示Cache到期策略,例如儲存一定時間後到期。它也經常和ChangeMonitor一起使用,以實現更複雜的策略。
ChangeMonitor則主要負責CachePool對象的狀態維護,判斷對象是否需要更新。它也是一個抽象類別,系統也提供了幾個常見的實現:CacheEntryChangeMonitor、FileChangeMonitor、HostFileChangeMonitor、SqlChangeMonitor。
1、首先建立一個一般控製程序,添加一個類,其中代碼如下
#region class MyCachePool { ObjectCache cache = MemoryCache.Default; const string CacheKey = "TestCacheKey"; //定義字串類型常量CacheKey並賦初值為TestCacheKey,那麼不能再改變CacheKey的值 //如執行CacheKey="2"; 就會運行錯誤在整個程式中 a的值始終為TestCacheKey public string GetValue() { var content = cache[CacheKey] as string; if(content == null) { Console.WriteLine("Get New Item"); //SlidingExpiration = TimeSpan.FromSeconds(3) //第一種到期策略,當對象3秒鐘內沒有得到訪問時,就會到期。如果對象一直被訪問,則不會到期。 AbsoluteExpiration = DateTime.Now.AddSeconds(3) //第二種到期策略,當超過3秒鐘後,Cache內容就會到期。 content = Guid.NewGuid().ToString(); cache.Set(CacheKey, content, policy); } else { Console.WriteLine("Get cached item"); } return content; }#endregion
再在主程式入口
static void Main(string[] args) { MyCachePool pool = new MyCachePool(); MyCachePool1 pool1 = new MyCachePool1(); while(true) { Thread.Sleep(1000); var value = pool.GetValue(); //var value = pool1.myGetValue(); Console.WriteLine(value); Console.WriteLine(); }}
這個例子建立了一個儲存3秒鐘Cache:三秒鐘內擷取到的是同一個值,超過3秒鐘後,資料到期,更新Cache,擷取到新的值。
到期策略:
從前面的例子中我們可以看到,將一個Cache對象加入CachePool中的時候,同時加入了一個CacheItemPolicy對象,它實現著對Cache對象超期的控制。例如前面的例子中,我們設定逾時策略的方式是:AbsoluteExpiration = DateTime.Now.AddSeconds(3)。它表示的是一個絕對時間到期,當超過3秒鐘後,Cache內容就會到期。
除此之外,我們還有一種比較常見的超期策略:按訪問頻度決定超期。例如,如果我們設定如下超期策略: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:\\Users\\Administrator\\Desktop\\test.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; }