Cache 類別
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
實作 Web 應用程式的快取。 此類別無法獲得繼承。
public ref class Cache sealed : System::Collections::IEnumerable
public sealed class Cache : System.Collections.IEnumerable
type Cache = class
interface IEnumerable
Public NotInheritable Class Cache
Implements IEnumerable
- 繼承
-
Cache
- 實作
範例
下列範例是一個頁面,顯示使用者指派給快取中專案的值,然後在從快取中移除專案時通知他們。 它會建立方法 RemovedCallback
,其中包含委派的 CacheItemRemovedCallback
簽章,以在移除快取專案時通知使用者,並使用 CacheItemRemovedReason 列舉來告訴他們為何移除它。 此外,它會使用 Cache.Item[] 屬性將物件新增至快取,並擷取這些物件的值。 在方法中AddItemToCache
Cache.Add,它會使用 方法將專案新增至快取。 若要使用 CacheItemRemovedCallback
委派,您必須使用此方法或 Cache.Insert 方法將專案新增至快取,如此一來,ASP.NET 就可以在移除專案時自動進行適當的方法呼叫。 自定義 RemoveItemFromCache
方法會 Cache.Remove 使用 方法來明確刪除快取中的專案,導致 RemovedCallback
叫用 方法。
注意
下列代碼段所存取的 Cache 實例是這個範例所繼承的物件成員 Page 。
<html>
<Script runat=server language="C#">
// <snippet2>
static bool itemRemoved = false;
static CacheItemRemovedReason reason;
CacheItemRemovedCallback onRemove = null;
public void RemovedCallback(String k, Object v, CacheItemRemovedReason r){
itemRemoved = true;
reason = r;
}
// </snippet2>
// <snippet3>
public void AddItemToCache(Object sender, EventArgs e) {
itemRemoved = false;
onRemove = new CacheItemRemovedCallback(this.RemovedCallback);
if (Cache["Key1"] == null)
Cache.Add("Key1", "Value 1", null, DateTime.Now.AddSeconds(60), Cache.NoSlidingExpiration, CacheItemPriority.High, onRemove);
}
// </snippet3>
// <snippet4>
public void RemoveItemFromCache(Object sender, EventArgs e) {
if(Cache["Key1"] != null)
Cache.Remove("Key1");
}
// </snippet4>
</Script>
<body>
<Form runat="server">
<input type=submit OnServerClick="AddItemToCache" value="Add Item To Cache" runat="server"/>
<input type=submit OnServerClick="RemoveItemFromCache" value="Remove Item From Cache" runat="server"/>
</Form>
<% if (itemRemoved) {
Response.Write("RemovedCallback event raised.");
Response.Write("<BR>");
Response.Write("Reason: <B>" + reason.ToString() + "</B>");
}
else {
// <snippet5>
Response.Write("Value of cache key: <B>" + Server.HtmlEncode(Cache["Key1"] as string) + "</B>");
// </snippet5>
}
%>
</body>
</html>
<%@ Page Language="VB" %>
<html>
<Script runat=server>
' <snippet2>
Shared itemRemoved As boolean = false
Shared reason As CacheItemRemovedReason
Dim onRemove As CacheItemRemovedCallback
Public Sub RemovedCallback(k As String, v As Object, r As CacheItemRemovedReason)
itemRemoved = true
reason = r
End Sub
' </snippet2>
' <snippet3>
Public Sub AddItemToCache(sender As Object, e As EventArgs)
itemRemoved = false
onRemove = New CacheItemRemovedCallback(AddressOf Me.RemovedCallback)
If (IsNothing(Cache("Key1"))) Then
Cache.Add("Key1", "Value 1", Nothing, DateTime.Now.AddSeconds(60), Cache.NoSlidingExpiration, CacheItemPriority.High, onRemove)
End If
End Sub
' </snippet3>
' <snippet4>
Public Sub RemoveItemFromCache(sender As Object, e As EventArgs)
If (Not IsNothing(Cache("Key1"))) Then
Cache.Remove("Key1")
End If
End Sub
' </snippet4>
</Script>
<body>
<Form runat="server">
<input type=submit OnServerClick="AddItemToCache" value="Add Item To Cache" runat="server"/>
<input type=submit OnServerClick="RemoveItemFromCache" value="Remove Item From Cache" runat="server"/>
</Form>
<%
If (itemRemoved) Then
Response.Write("RemovedCallback event raised.")
Response.Write("<BR>")
Response.Write("Reason: <B>" + reason.ToString() + "</B>")
Else
' <snippet5>
Response.Write("Value of cache key: <B>" + Server.HtmlEncode(CType(Cache("Key1"),String)) + "</B>")
' </snippet5>
End If
%>
</body>
</html>
備註
每個應用程式域都會建立此類別的一個實例,只要應用程式域保持作用中,它就會維持有效狀態。 這個類別實例的相關信息可透過 Cache
對象的 屬性 HttpContext 或 Cache
對象的 屬性 Page 取得。
注意
類別 Cache 不適用於 ASP.NET 應用程式外部。 其設計及測試用於 ASP.NET,以提供 Web 應用程式的快取。 對於其他類型的應用程式,例如控制台應用程式或 Windows Forms 應用程式,請使用 ObjectCache 類別。
建構函式
Cache() |
初始化 Cache 類別的新執行個體。 |
欄位
NoAbsoluteExpiration |
在 Insert(String, Object) 方法呼叫中的 |
NoSlidingExpiration |
使用來做為 Insert(String, Object) 或 Add(String, Object, CacheDependency, DateTime, TimeSpan, CacheItemPriority, CacheItemRemovedCallback) 方法呼叫中的 |
屬性
Count |
取得快取中所儲存的項目數。 |
EffectivePercentagePhysicalMemoryLimit |
取得應用程式可以消耗的實體記憶體百分比,超過這個百分比,ASP.NET 就會開始移除快取區中的項目。 |
EffectivePrivateBytesLimit |
取得快取可用的位元組數目。 |
Item[String] |
取得或設定在指定索引鍵的快取項目。 |
方法
明確介面實作
IEnumerable.GetEnumerator() |
傳回列舉值,可逐一查看 Cache 物件集合。 |
擴充方法
Cast<TResult>(IEnumerable) |
將 IEnumerable 的項目轉換成指定的型別。 |
OfType<TResult>(IEnumerable) |
根據指定的型別來篩選 IEnumerable 的項目。 |
AsParallel(IEnumerable) |
啟用查詢的平行化作業。 |
AsQueryable(IEnumerable) |
將 IEnumerable 轉換成 IQueryable。 |
適用於
執行緒安全性
此型別具備執行緒安全。