达内广州IT培训
美国上市IT培训机构

18589266248

热门课程

.NET中Cache的应用

  • 时间:2016-08-03 19:40
  • 发布:广州IT培训学校
  • 来源:企业面试题

这次探讨Cache 即高速缓存 ,我想很多人对他的第一印象一定像我一样,感觉他一定能提高系统得性能和运行速度。Net推出cache的初衷确实是这样的。那么cache是如何提高系统性能与运行速度呢?

这次探讨Cache 即高速缓存 ,我想很多人对他的第一印象一定像我一样,感觉他一定能提高系统得性能和运行速度。的确。Net推出cache的初衷确实是这样的。那么cache是如何提高系统性能与运行速度呢?是不是在任何情况下用cache都能提高性能?是不是cache用的越多就越好呢?我在近期开发的项目中有所体会,写下来当作总结也希望能跟大家一起探讨探讨,有错误的地方希望大家批评指正。

1.Cache 是如何工作的

Cache 是分配在服务器上的一个公共的内存片。

所谓公共指的cache只要一创建是任何一个客户端浏览器都可以通过后台代码访问到它,它面向的是所有用户,相对而言session也是服务器上的一段内存,但他面向的是单个用户。它是服务器的一段内存块,也就是说每个cache一经创建就占用了服务器资源的。所以从这点来说我们就可以说:并不是cache越多越好。

cache 是有时间限制的,超过了服务器设定的过期时间,它就会被服务器回收。

c.cache 可以存放任何对象

2.Cache 如何创建以及如何销毁

创建cache

在。Net环境下通过Cache.Insert(string key,object o)方法创建。其中key 代表cache的ID,o代表存到cache里的对象。

销毁cache.

通过方法Cache.Remove(string key)其中key 代表cache的 ID.

调用cache.

Cache支持装箱/拆箱操作。如你可以把一个DataSet对象ds通过Cache.Insert(“dsCache”,ds)的方式存到Cache中,可以通过拆箱操作 DataSet ds = (DataSet)Cache[“dsCache”]来访问它。

3.什么时候用cache

Cache 一般用于数据较固定,用的较频繁的地方。例如可以把进销存系统中可以把产品信息存入cache,在用户调用产品信息时通过调用cache即可,这样从很大程度上减少了用户与数据库的交互,提高了系统的性能。反之,cache不适合用在数据变动快,使用范围很窄的地方。例如把一个具体采购单存入 cache中。

4.cache 调用注意事项

Cache是有时间限制的。超过了服务器设置的过期时间,就会被服务器回收。当cache被回收后对应的内存块就会被清空,再次通过cache[“cachekey”]访问对象时返回的就是null值。所以以下这种调用就会出现异常

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();

}

在.NET中,Cache的存在可以依赖多中方式,主要用到HttpContext.Current.Cache类

在这里,我主要写几种依赖方式

1:不依赖任何条件

HttpContext.Current.Cache.Insert(string cacheName,object obj)

理论上是Cache会永久保存,但是当服务器重新启动,内存紧张的时候也会丢失.

2:HttpContext.Current.Cache.Insert(string key, object value, CacheDependency dependencies, DateTime absoluteExpiration, TimeSpan

slidingExpiration);

//CacheDependency缓存依赖项,absoluteExpiration绝对过期时间,slidingExpiration最后一次访问的时间隔

//我们主要讲两种Cache依赖

2.1:文件依赖,so simple//只要文件改动,Cache移出

HttpContext.Current.Cache.Insert(cacheName,ojb, new System.Web.Caching.CacheDependency(FilePath));

2.2:SqlServer数据库依赖//我这里是SQL2005

首先看数据库通知是否可用,记得一定要开启通知

Select DATABASEpRoPERTYEX('数据库名','IsBrokerEnabled');如果值为1表示可用

alter database Game176Admin set ENABLE_BROKER ;//开启

alter database Game176Admin set DISABLE_BROKER;//关闭

在Global.asax文件中,我们在应用程序开始和结束时要做一些事情

void Application_Start(object sender, EventArgs e)

{

// 在应用程序启动时运行的代码

try

{

System.Data.SqlClient.SqlDependency.Start(string strCon);//开启

}

catch { }

}

void Application_End(object sender, EventArgs e)

{

// 在应用程序关闭时运行的代码

try

{

System.Data.SqlClient.SqlDependency.Stop(string strCon);

}

catch { }

}

准备工作已经完成

我们先写一个方法,添加数据库依赖

void AddSqlDependency(string strCon, string strSql, OnChangeEventHandler sqlDep_OnChange)

{

try

{

using (SqlConnection conn = new SqlConnection(strCon))

{

SqlCommand comm = new SqlCommand(strSql, conn);

SqlDependency sqlDep = new SqlDependency(comm);

sqlDep.OnChange += sqlDep_OnChange;

if (conn.State == ConnectionState.Closed) conn.Open();

comm.ExecuteNonQuery();

}

}

catch (Exception ex)

{

LogUtility.Add(ex);

}

}

//上面这个方法是告诉数据库,当你指定表数据改变,要移出缓存

我们现在可以来添加了

MyObject obj= HttpRuntime.Cache["cacheName"] as MyObject;

if (null == obj)

{

try

{

obj= GetObj(...);

}

catch (Exception ex)

{

LogUtility.Add(ex);

obj= null;

}

if (null != obj)

{

AddSqlDependency(strCon, "select id from dbo.tableName;select id1 from dbo.tableName1",

delegate(object sender, SqlNotificationEventArgs e)

{

//do something

HttpRuntime.Cache.Remove("cacheName");

});

HttpRuntime.Cache.Insert("cacheName", obj);

}

}

上面SQL语句中用到的表,只要这些表中的任何数据有改动,数据库都会通知,这时缓存会移动,select的字段和Cache没有关系,只有表名有关系,所有你要选择最小的字段.很多时候,为了这个字段,在设计表的时候都为多加一个最小的依赖列.

NOTE:任何Cache都可能丢失,使用前一定要做必要的检查,如:

MyObject obj=HttpContext.Current.Cache("CacheName") as MyObject;

if(null==obj)

{

obj=.......

HttpContext.Current.Cache.Insert("CacheName",obj);

}

上一篇:web前端工程师企业面试题
下一篇:软件测试面试必备的一些基础理论概念

马上预约三天免费体验课

姓名:

电话:

web前端工程师企业面试题

C++ 类模板和模板类的深入解析

网页设计师的职场规划

软件测试专业测试题

选择城市和中心
贵州省

广西省

海南省