明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

實(shí)戰(zhàn) .Net 數(shù)據(jù)訪問層 - 17

[摘要]GetCache的代碼很簡單:有則取之,無則填之,“是否過期”是其有效性的唯一判斷條件!接下來,作者就這個(gè)“是否過期”問題來進(jìn)行一些探索,看看到底是怎么回事。 Ok,還是先請(qǐng)大家看段代碼: 代碼15...
GetCache的代碼很簡單:有則取之,無則填之,“是否過期”是其有效性的唯一判斷條件!接下來,作者就這個(gè)“是否過期”問題來進(jìn)行一些探索,看看到底是怎么回事。



Ok,還是先請(qǐng)大家看段代碼:



代碼15:過期無效之Cache篇!

public class CacheManager

{

private bool IsCacheExpired(string key)

{

bool bExpired = false;



if (HttpContext.Current != null)

{

// Web cache自動(dòng)支持thread-safe,無須鎖定資源

if (HttpContext.Current.Cache[key] == null)

bExpired = true;

}

else

{

// Windows cache是自己實(shí)現(xiàn)的,不確保thread-safe,必須鎖定資源

lock (_htWinAppCache)

{

if (_htWinAppCache[key] == null)

bExpired = true;

else

{

WinAppCache cache = (WinAppCache)

_htWinAppCache[key];



if (cache.IsExpired())

{

cache = null;

_htWinAppCache[key] = null;

bExpired = true;

}

}

}

}



return bExpired;

}

}

























































































各位,從上面的代碼中,是否看出了一些端倪?



由于Web Appliction Cache(通過HttpContext.Current != null判斷是否Web ApplicationJ)得到了.NET Framework的直接支持,所以判斷“是否過期”非常方便,也不存在任何thread-safe問題J。但這個(gè)問題對(duì)于Windows Application來說就不太美妙了,既要自己實(shí)現(xiàn)IsExpired,又要擔(dān)心多線程并發(fā)訪問時(shí)的種種問題,真是吃力不討好的苦差啊L!上面代碼中的“_htWinAppCache”(自定義Cache)以及“l(fā)ock (_htWinAppCache)”(確保thread-safe)就是為了應(yīng)付Windows Application而采取的兩種非常手段!



可能有朋友會(huì)問了,Windows Application也要考慮Cache Management問題嗎?我的回答是:看情況而定!

對(duì)于普通的Client Windows Application,確實(shí)很少(請(qǐng)注意:不是沒有)涉及這個(gè)話題,但對(duì)于Server Application,例如:Remoting Server,Windows Service(WebServices不在此列),都促使我們不得不面對(duì)“嚴(yán)峻的現(xiàn)實(shí)”L(.NET Framework怎么就沒有提供System.Windows.Caching命名空間呢?害得我們不得不另起爐灶L)!



上面的代碼就是考慮到Web Application與Windows Application并存的情況下,我們?cè)撊绾螌?shí)現(xiàn)Cache Management支持!



當(dāng)前版本中,作者實(shí)現(xiàn)Windows Application下的“是否過期”非常簡單:就是看它被訪問過幾次!而這個(gè)次數(shù),當(dāng)然必須在配置信息中進(jìn)行設(shè)定了(請(qǐng)參考本段最后的一個(gè)配置樣例)!

Web Application中的Cache Management自動(dòng)化程度雖然很高,但也“逃不過”配置一關(guān),而讀取完配置信息后的處理工作就當(dāng)仁不讓地落到了Parameter Classes的肩上(請(qǐng)參考上面的Cache Management之“結(jié)構(gòu)示意圖”)!



下一段:http://www.csdn.net/develop/Read_Article.asp?id=27561