C#中缓存的基本用法总结

本文初步探讨了C#缓存的原理及应用,并以实例加以分析总结,这些对C#初学者来说是很有必要熟练掌握的内容。具体如下:

一、概述:

缓存应用目的:缓存主要是为了提高数据的读取速度。因为服务器和应用客户端之间存在着流量的瓶颈,所以读取大容量数据时,使用缓存来直接为客户端服务,可以减少客户端与服务器端的数据交互,从而大大提高程序的性能。

1、缓存的引用空间:System.Web.Caching; 缓存命名空间主要提供三种操作:缓存数据对象、对象的缓存依赖和数据库的缓存依赖。其中缓存任何对象都使用一个类Cache,但当缓存发生改变时,普通对象和数据库对象的依赖处理不同。

2、管理缓存类:Cache

Cache类用来存储数据对象,并提供方法对这些对象进行编辑。Cache类属于字典类,其根据一定的规则存储用户需要的数据,这些数据的类型不受限制,可以是字符串、数组、数据表、Dataset和哈希表等。
使用Cache类的优点是当缓存的数据发生变化时,Cache类会让数据失效,并实现缓存数据的重新添加,然后通知应用程序,报告缓存的及时更新。

二、方法详解:

Cache类的方法主要提供对缓存数据的编辑操作,如增、删、改等。

Add 将数据添加到Cache对象
Insert 向Cache中插入数据项,可用于修改已经存在的数据缓存项
Remove 移除Cache对象中的缓存数据项
Get 从Cache对象中获取指定的数据项,注意返回的是Object类型,需要进行类型转换
GetType 从Cache对象中获取数据项的类型,判断数据类型后,方便进行转换

最需要注意的是Add方法,其使用语法如下:

public Object Add (
string key,
Object value,
CacheDependency dependencies,
DateTime absoluteExpiration,
TimeSpan slidingExpiration,
CacheItemPriority priority,
CacheItemRemovedCallback onRemoveCallback
)

在使用Add方法时,以上7个参数是必需的,其代表意义如下:
— 参数“key”代表缓存数据项的键值,必须是唯一的。
— 参数“value”代表缓存数据的内容,可以是任意类型。
— 参数“dependencies”表示缓存的依赖项,也就是此项的更改意味着缓存内容已经过期。如果没有依赖项,可将此值设置为NULL。
— 参数“absoluteExpiration”是日期型数据,表示缓存过期的时间,.NET 2.0提供的缓存在过期后是可以使用的,能使用多长时间,就看这个参数的设置。
— 参数“slidingExpiration”的类型表示一段时间间隔,表示缓存参数将在多长时间以后被删除,此参数与absoluteExpiration参数相关联。
— 参数“priority”表示撤销缓存的优先值,此参数的值取自枚举变量“CacheItemPriority”,优先级低的数据项将先被删除。此参数主要用在缓存退出对象时。
— 参数“onRemoveCallback”表示缓存删除数据对象时调用的事件,一般用做通知程序。

应用代码如下:

ArrayList myarray = new ArrayList();
        myarray.Add("1.学习天地1");
        myarray.Add("2.学习天地1");
        myarray.Add("3.学习天地1");
        myarray.Add("4.学习天地1");
        string item = "这是一条缓存";
        Cache["item"] = item;//赋值
        Response.Write(Cache.Get("item") + "<br/>");

        item = "更改一条缓存数据";
        Cache.Insert("item", item);//更改缓存值
        Response.Write(Cache.Get("item") + "<br/>");

        //Cache.Remove("item"); //移除缓存值
        //Response.Write(Cache.Get("item") + "<br/>");

        Response.Write(Cache["item"].GetType().Name + "<br/>");//GetType获得Cache的数据类型
        Response.Write(Cache.Get("Array") + "<br/>");//GetType获得Cache的数据类型

        IDictionaryEnumerator bianli = Cache.GetEnumerator();//遍历整个缓存
        while (bianli.MoveNext())
        {
          Response.Write(bianli.Value + "<br/>");
        }
        Response.Write("获取缓存数量:" + Cache.Count);

        if (Cache["Array"] == null)
        {//当缓存Array不存在时,添加缓存,缓存时间设定为5秒
          Cache.Add("Array", myarray, null, DateTime.Now.AddSeconds(5), TimeSpan.Zero, CacheItemPriority.Normal, null);
        }

3、  缓存依赖类:CacheDependency类

功能说明:

CacheDependency类被称为是缓存依赖类,其具体意义表现在当缓存对象的实际数据发生改变时,它能及时通知缓存对象。例如缓存对象“Category”保存的是一个XML文件的数据,如果XML文件发生了变化,那么系统通过CacheDependency类就会及时更新缓存对象“Category”的内容,这样就能保证用户读取的永远是最新的数据。

代码实例:

CaCheXml.xml文件如下:

<?xml version="1.0" encoding="utf-8" ?>
<book>
 <bookinfo>
  <name>英国古代</name>
  <price>28.00</price>
 </bookinfo>
 <bookinfo>
  <name>中国历史</name>
  <price>20.00</price>
 </bookinfo>
 <bookinfo>
  <name>中国历史1232sdf2</name>
  <price>20.00</price>
 </bookinfo>
</book>

后台代码如下:

private static CacheDependency Mydata;
    protected void Page_Load(object sender, EventArgs e)
    {
      if (!IsPostBack)
      {
        DataSet ds = new DataSet();
        ds.ReadXml(Server.MapPath("Cachexml.xml"));//读取Xml里面数据
        if (Cache["CXml"] == null)
        {
          //创建缓存依赖项
          Mydata = new CacheDependency(Server.MapPath("Cachexml.xml"));
          Cache.Add("CXml", ds, Mydata, DateTime.Now.AddSeconds(10), TimeSpan.Zero, CacheItemPriority.Normal, null);
        }
      }
    }

    protected void Button1_Click(object sender, EventArgs e)
    {
      if (Mydata.HasChanged)
      {//判断缓存是否更改
        Response.Write("缓存已经更改,更改时间为"+Mydata.UtcLastModified);//获取缓存的跟新时间
      }
      if (Cache["CXml"] == null)
      {//当xml文件被改动时缓存从新加载
        DataSet ds = new DataSet();
        ds.ReadXml(Server.MapPath("Cachexml.xml"));//读取Xml里面数据
        //创建缓存依赖项
        Mydata = new CacheDependency(Server.MapPath("Cachexml.xml"));
        Cache.Add("CXml", ds, Mydata, DateTime.Now.AddSeconds(60), TimeSpan.Zero, CacheItemPriority.Normal, null);
      }
      this.GridView1.DataSource = Cache["CXml"];
      this.GridView1.DataBind();
    }
(0)

相关推荐

  • C#默认双缓冲技术实例分析

    本文实例讲述了C#默认双缓冲技术.分享给大家供大家参考.具体如下: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace advanced_drawing { public partial class F

  • C#词法分析器之输入缓冲和代码定位的应用分析

    一.输入缓冲 在介绍如何进行词法分析之前,先来说说一个不怎么被提及的问题--怎么从源文件中读取字符流.为什么这个问题这么重要呢?是因为在词法分析中,对字符流是有要求的,它必须能够支持回退操作(就是将多个字符放回到流中,以后会再次被读取). 先来解释下为什么需要支持回退操作,举个简单的例子来说,现在要对两个模式进行匹配: 图 1 流的回退过程 上面是一个简单的匹配过程,仅为了展示回退过程,在后面实现 DFA 模拟器时会详细解释是如何匹配词素的. 现在来看看 C# 中与输入相关的类,有 Stream

  • asp.net(C#)遍历memcached缓存对象

    STATS命令 遍历memcached缓存对象(C#)转载之青草堂 出于性能考虑,memcached没有提供遍历功能,不过我们可以通过以下两个stats命令得到所有的缓存对象. 1.stats items 显示各个slab中item的数目. 2.stats cachedump slab_id limit_num 显示某个slab中的前limit_num个key列表,显示格式:ITEM key_name [ value_length b; expire_time|access_time s] 除了

  • C#读取中文字符及清空缓冲区的实现代码

    开时始,得到的中文文件中的字符是乱码的,鸟符号看的头晕.于是就细究streamreader读取的编码格式,默认的编码是ascii,单字节的,就尝试utf8,乱码:尝试gb2312,OK! 可另一个问题又出现了,得到的两个文件的行数都不到1500行,尝试N次还是不行,很郁闷.google了下,看到try catch,就想到释放缓冲区,结果很HAPPY! 复制代码 代码如下: private static void FnFileProcess() { StreamReader reader = ne

  • C# Memcached缓存用法实例详解

    本文实例讲述了C#中Memcached缓存的用法,分享给大家供大家参考.具体方法如下: ICacheStrategy.cs文件如下: 复制代码 代码如下: public interface ICacheStrategy {         /// <summary>         /// 添加数据到缓存         /// </summary>         /// <param name="objId">缓存名称</param>

  • C#自定义缓存封装类实例

    本文实例讲述了C#自定义缓存封装类.分享给大家供大家参考.具体如下: 这个自定义的C#类封装了部分常用的缓存操作,包括写入缓存,读取缓存,设置缓存过期时间等等,简化了C#的缓存操作,代码非常简单,易于阅读. using System; using System.Web; namespace DotNet.Utilities { /// <summary> /// 缓存相关的操作类 /// </summary> public class DataCache { /// <sum

  • C#双缓冲实现方法(可防止闪屏)

    本文实例讲述了C#双缓冲实现方法.分享给大家供大家参考,具体如下: // 该调用是 Windows.Forms 窗体设计器所必需的. InitializeComponent(); // TODO: 在 InitComponent 调用后添加任何初始化 this.SetStyle(ControlStyles.AllPaintingInWmPaint,true); //开启双缓冲 this.SetStyle(ControlStyles.DoubleBuffer,true); this.SetStyl

  • C#双缓冲技术实例详解

    本文实例分析了C#双缓冲技术.分享给大家供大家参考,具体如下: 双缓冲解决闪烁问题. 整理: GDI+的双缓冲问题 一直以来的误区:.net1.1 和 .net 2.0 在处理控件双缓冲上是有区别的. .net 1.1 中,使用:this.SetStyle(ControlStyles.DoubleBuffer, true); .net 2.0中,使用:this.SetStyle(ControlStyles.OptimizedDoubleBuffer, true); 导致画面闪烁的关键原因分析:

  • c#自带缓存使用方法 c#移除清理缓存

    复制代码 代码如下: /// <summary>/// 获取数据缓存/// </summary>/// <param name="CacheKey">键</param>public static object GetCache(string CacheKey){    System.Web.Caching.Cache objCache = HttpRuntime.Cache;    return objCache[CacheKey];}/

  • C#手工双缓冲技术用法实例分析

    本文实例讲述了C#手工双缓冲技术.分享给大家供大家参考.具体如下: using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; namespace advanced_drawing { public partial class F

随机推荐