c#如何使用缓存提高程序效率

c#如何使用缓存提高程序效率,第1张

缓存的技术应用应该是非广泛的。而它的作用也是为了提高系统或者网站的执行效率。下面是四种常见的缓存技术:

一.OutputCaching

由于IIS的一些特性,默认情况下OutputCache是打开的,但是要对某些请求进行缓存,还需要开发者进行定制,而且默认情况下,Output Cache 会被缓存到硬盘上,我们可以通过修改DiskCacheable的属性来设置其是否缓存,还可以通过Web config里配置缓存文件的大小。

<%@ OutputCacheDuration="3600" VaryByParam="state" DiskCacheable="true" %>

一般用硬盘缓存是考虑到页面送显的数据比较大,相对内存缓存来说,它的容量大,但是访问速度慢点,如果把周期设太短,使用硬盘缓存的效率就不大好。对于Output Cache的定制,有两种方法,一种是基于底层的API技术,一种是基于高层的@OutputCaching:

1.基于高层的@OutputCaching

A.由参数改变缓存内容:有些时候我们需要根据用户的请求来生成页面,但是用户的请求只有有限的几种组合,这个时候就可以根据用户请求来生成几种缓存页面,来进行缓存。

<%@ OutputCache Duration ="60" VaryByParam = "state" %>

<asp:SqlDataSourceID="SqlDataSource1" runat="server">

<SelectParameters>

<asp:QueryStringParameter Name="state"QueryStringField="state" DefaultValue="CA" />

</SelectParameters>

</asp:SqlDataSource>

B.回调缓存:可以针对每个请求在页面中插入动态的部分,以弥补单独使用静态缓存的不足:

动态的部分用Substitution控件,Substitution控件是一个容器

<asp:SubstitutionID="Substitution1" runat="server" MethodName =""/>

MethodName 里面放入要调用的方法内容。

2. 使用API定制缓存:

通过设置System.Web.HttpCachePolicy属性来进行配置

<%@ OutputCache Duration="60"VaryByParam="none" %>

就可以写成

Response.Cache.SetExpires(DateTime.Now.AddSeconds(60))

Response.Cache.SetCacheability(HttpCacheability.Public)

二.FragmentCaching

作为Output的缓存的附加功能,还提供一种缓存技术,专门用于缓存用户控件。在用户控件中设置:

<%@ OutputCache Duration="60"VaryByParam="none" %>

但在引用用户控件的页面不设置缓存。这样的话,页面中除了用户控件是静态的,其他都是动态的。

缓存用户空间同样还可以使用控件作为参数来源。通过指定控件作为缓存控件的数据来源,可以达到缓存控件数据的目的,和上面一样。

三.DataCaching

Asp.net提供了一种非常快捷的方法进行数据库缓存,用户可以非常简单方便的对页面变量进行缓存。并以此提高程序效率。一个页面变量的缓存生命周期与应用程序的缓存生命周期相同

实现是把数据放在Cache中,如:

source = new DataView(ds)

Cache("MyCache") = source

MyCache这个变量其实就是一个XML文件。

四.SQL Caching

通过配置数据库连接池,只有当数据库数据被改变的时候,缓存才会改变。

开个DOS窗口:

C:\>dir aspnet_regsql.exe/s ——这个文件是专门注册SQL连接池的,它对SQLSever 7.0以上都有专门的支持,我们通过写一些专门的语句来配置这个注册连接池,可以把连接池和本地的应用程序(Asp.net服务器,即IIS)做一个连接。连接池只能监视有限的几个库,不然连接池的负载太大。使用SQL Caching:

先注册,如: aspnet_regsql.exe-S".\SQLExpress"-E-d"pubs"-ed

aspnet_regsql.exe-S".\SQLExpress"-E-d"pubs"-et-t"authors"

其中:- S".\SQLExpress" 表示要使用的SQL Server实例为".\SQLExpress"。-E 表示使用当前windows凭证进行身份验证。-d"pubs"表示用于应用程序服务的数据库名称叫"pubs"。-ed表示为SQL 缓存依赖项启用数据库。-et 表示为SQL 缓存依赖项启用表。-t"authors"表的名称为"authors"。

然后页面上:

<%@ OutputCacheDuration="99999999" VaryByParam="none"SqlDependency="Pubs.Authors" %>

就OK了。

缓存的介质一般是内存,所以读写速度很快。但如果缓存中存放的数据量非常大时,也会用硬盘作为缓存介质。缓存的实现不仅仅要考虑存储的介质,还要考虑到管理缓存的并发访问和缓存数据的生命周期。

缓存就是数据交换的缓冲区(称作Cache),当某一硬件要读取数据时,会首先从缓存中查找需要的数据,如果找到了则直接执行,找不到的话则从内存中找。由于缓存的运行速度比内存快得多,故缓存的作用就是帮助硬件更快地运行。

因为缓存往往使用的是RAM(断电即掉的非永久储存),所以在用完后还是会把文件送到硬盘等存储器里永久存储。电脑里最大的缓存就是内存条了,最快的是CPU上镶的L1和L2缓存,显卡的显存是给显卡运算芯片用的缓存,硬盘上也有16M或者32M的缓存。

你说的“缓存模块”提供数据访问的接口,其他程序通过“缓存模块”获取数据,不直接访问数据库;这些不是ODBC驱动的所提供的吗?不实用第三方组件,幸亏是mysql。mysql数据库自己实现了C语言访问数据的数据库文件,sql.h文件,你的项目中加入这个文件,用人家提供的函数访问数据库。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10002899.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存