Cache 即高速緩存 ,我想非常多人對他的第一印象一定像我相同,感覺他一定能提高系統(tǒng)得性能和運行速度。的確。Net推出cache的初衷確實是這樣的。那么cache是怎么提高系統(tǒng)性能和運行速度呢?是不是在所有情況下用cache都能提高性能?是不是cache用的越多就越好呢?我在近期研發(fā)的項目中有所體會,寫下來當作總結(jié)也希望能跟大家一起探討探討,有錯誤的地方希望大家批評指正。
1.Cache 是怎么工作的
Cache 是分配在服務器上的一個公共的內(nèi)存片。
所謂公共指的cache只要一創(chuàng)建是所有一個客戶端瀏覽器都能通過后臺代碼訪問到他,他面向的是所有用戶,相對而言session也是服務器上的一段內(nèi)存,但他面向的是單個用戶。他是服務器的一段內(nèi)存塊,也就是說每個cache一經(jīng)創(chuàng)建就占用了服務器資源的。所以從這點來說我們就能說:并不是cache越多越好。
cache 是有時間限制的,超過了服務器設(shè)定的過期時間,他就會被服務器回收。
c.cache 能存放所有對象
2.Cache 怎么創(chuàng)建及怎么銷毀
創(chuàng)建cache
在。Net環(huán)境下通過Cache.Insert(string key,object o)方法創(chuàng)建。其中key 代表cache的ID,o代表存到cache里的對象。
銷毀cache.
通過方法Cache.Remove(string key)其中key 代表cache的 ID.
調(diào)用cache.
Cache支持裝箱/拆箱操作。如你能把一個DataSet對象ds通過Cache.Insert(“dsCache”,ds)的方式存到Cache中,能通過拆箱操作 DataSet ds = (DataSet)Cache[“dsCache”]來訪問他。
3.什么時候用cache
Cache 一般用于數(shù)據(jù)較固定,用的較頻繁的地方。例如能把進銷存系統(tǒng)中能把產(chǎn)品信息存入cache,在用戶調(diào)用產(chǎn)品信息時通過調(diào)用cache即可,這樣從非常大程度上減少了用戶和數(shù)據(jù)庫的交互,提高了系統(tǒng)的性能。反之,cache不適合用在數(shù)據(jù)變動快,使用范圍非常窄的地方。例如把一個具體采購單存入 cache中。
4.cache 調(diào)用注意事項
Cache是有時間限制的。超過了服務器設(shè)置的過期時間,就會被服務器回收。當cache被回收后對應的內(nèi)存塊就會被清空,再次通過cache[“cachekey”]訪問對象時返回的就是null值。所以以下這種調(diào)用就會出現(xiàn)異常
DataSet ds = (DataSet)Cache[“cacheds”]; DataRow dr = ds.Table[0].Row[0]; //出錯,ds為null值,不存在表0。
正確的寫法應該是:
DataSet ds If(Cache[“cacheds”] != null) { ds = (DataSet)Cache[“cacheds”]; } Else { ds= GetDsFromDataBase(); } DataRow dr = ds.Table[0].Row[0];