Microsoft Enterprise Library 5.0 |
Adding Items to the Cache |
Caches store items that are either expensive to create or expensive to transport. For example, in a retail application, a list of products must be passed from the data access components to the user interface components so that the product list can be displayed to the users. The data represents real-world business entities, such as products or orders. To increase performance, some of these items may be added to the cache.
Typical Goals
In this scenario, you want to add items to the cache. You may also want to set the expiration periods for the expiration process and the priorities for the scavenging process.
Solution
Use the Add method provided by the CacheManager class. The CacheManager class adds a new item to the cache. If you do not explicitly set the expiration period and the priority properties, they are set to the default settings. The default settings in this case are NeverExpired and Normal. If another item already exists with the same key, that item is removed before the new item is added. If any failure occurs during this process, the cache is restored to its original state.
Using the Add Method
The following code shows how to use the Add method. It creates an object of type Product and then adds it to the cache with a scavenging priority of Normal, an instruction not to refresh the item if it expires, and an expiration date of 5 minutes from the last time the item was accessed.
Note: |
---|
The code does not include the Product class definition, and assumes that you resolve the class to obtain an instance of the default configured CacheManager class. For more information on instantiating objects, see Creating and Referencing Enterprise Library Objects. |
C# | Copy Code |
---|---|
public void ExampleScenario(ICacheManager productsCache) { string id = "ProductOneId"; string name = "ProductOneName"; int price = 50; Product newProduct = new Product(id, name, price); productsCache.Add(newProduct.ProductID, newProduct, CacheItemPriority.Normal, null, new SlidingTime(TimeSpan.FromMinutes(5))); } |
Visual Basic | Copy Code |
---|---|
Public Sub ExampleScenario(ByVal productsCache As ICacheManager) Dim id As String = "ProductOneId" Dim name As String = "ProductOneName" Dim price As Integer = 50 Dim newProduct As Product = New Product(id, name, price) productsCache.Add(newProduct.ProductID, newProduct, CacheItemPriority.Normal, _ Nothing, New SlidingTime(TimeSpan.FromMinutes(5))) End Sub |
Refreshing Removed Items
By using the Add method, you can specify an object that implements the interface ICacheItemRefreshAction. The Refresh method of the object is called whenever an item is removed from the cache, providing the opportunity to refresh items in the cache.
The following code shows a class that implements the ICacheItemRefreshAction interface.
C# | Copy Code |
---|---|
[Serializable] public class ProductCacheRefreshAction : ICacheItemRefreshAction { public void Refresh(string key, object expiredValue, CacheItemRemovedReason removalReason) { // Item has been removed from cache. Perform desired actions here, based on // the removal reason (for example, refresh the cache with the item). } } |
Visual Basic | Copy Code |
---|---|
<Serializable()> _ Public Class ProductCacheRefreshAction Implements ICacheItemRefreshAction Public Sub Refresh(ByVal removedKey As String, ByVal expiredValue As Object, ByVal removalReason As CacheItemRemovedReason) _ Implements ICacheItemRefreshAction.Refresh ' Item has been removed from cache. Perform desired actions here, based on ' the removal reason (for example, refresh the cache with the item). End Sub End Class |
Receiving notification of an item's removal from the cache requires that you specify the class implementing ICacheItemRefreshAction on the call to the Add method, as shown in the following code.
C# | Copy Code |
---|---|
public void ExampleScenario(ICacheManager productsCache) { string id = "ProductOneId"; string name = "ProductOneName"; int price = 50; Product newProduct = new Product(id, name, price); productsCache.Add(newProduct.ProductID, newProduct, CacheItemPriority.Normal, new ProductCacheRefreshAction(), new SlidingTime(TimeSpan.FromMinutes(5))); } |
Visual Basic | Copy Code |
---|---|
Public Sub ExampleScenario(ByVal productsCache As ICacheManager) Dim id As String = "ProductOneId" Dim name As String = "ProductOneName" Dim price As Integer = 50 Dim newProduct As Product = New Product(id, name, price) productsCache.Add(newProduct.ProductID, newProduct, CacheItemPriority.Normal, _ New ProductCacheRefreshAction, New SlidingTime(TimeSpan.FromMinutes(5))) End Sub |
Usage Notes
Here is some additional information:
- For more details of the integration of Enterprise Library and Unity, see Creating and Referencing Enterprise Library Objects.
- When adding any item to a cache configured to use a database as a backing store, the item's type must be serializable.
- The class implementing the ICacheItemRefreshAction interface must be serializable.
- For more information about serialization, see Object Serialization in the .NET Framework on MSDN.