就是希望让Web应用程序从一开始运行到结束都一直存在,有人就说为什么不用Application呢?其实Cache是可以一段时间内自动更新数据的,而Application就无法做成这样的,另外Application在Web这种高并发的系统中一定要考虑线程安全的问题,Application本身就不是线程安全的,而Cache就是线程安全。所以一般我都会在很多对象中我只从Web开始运行的时候从数据库或文件里获取一次数据,在不同的页面中,都是使用Cache的,而且Cache中的数据可能弄成自动更新的,所以一般情况不需要考虑数据更新的问题,另外Cache也是也应用程序关联的,全部可能驻留在该Web应用程序中的任何页面。
当然首先我们应该熟悉一下System.Web.Caching.Cache这个类,我这里也就只说说其中使用比较多的几个方法和属性,如果需要更详细的介绍请查阅MSDN。
首先介绍它的Add()方法,将指定的对象添加到Cache对象集合中。
Insert()方法将覆盖有相同Key的Cache顶。
Remove()从应用程序的Cache对象中移除指定项。
Count属性,获取存储在缓存中对象数。
这里我主要要说的是Add()方法,因为我们如果想要长期存在Cache并且在一段时间内自动替换Cache,就必须非常了解它。我们看看MSDN中对该方法的详细介绍吧。呵。
C#
public Object Add(
string key,
Object value,
CacheDependency dependencies,
DateTime absoluteExpiration,
TimeSpan slidingExpiration,
CacheItemPriority priority,
CacheItemRemovedCallback onRemoveCallback
)
参数
- key
- 类型:System.String
用于引用该项的缓存键。
- value
- 类型:System.Object
要添加到缓存的项。
- dependencies
- 类型:System.Web.Caching.CacheDependency
该项的文件依赖项或缓存键依赖项。当任何依赖项更改时,该对象即无效,并从缓存中移除。如果没有依赖项,则此参数包含 nullNothingnullptrnull 引用(在 Visual Basic 中为 Nothing)。
- absoluteExpiration
- 类型:System.DateTime
所添加对象将到期并被从缓存中移除的时间。如果使用可调到期,则 absoluteExpiration 参数必须为 NoAbsoluteExpiration。
- slidingExpiration
- 类型:System.TimeSpan
最后一次访问所添加对象时与该对象到期时之间的时间间隔。如果该值等效于 20 分钟,则对象在最后一次被访问 20 分钟之后将到期并从缓存中移除。如果使用绝对到期,则 slidingExpiration 参数必须为 NoSlidingExpiration。
- priority
- 类型:System.Web.Caching.CacheItemPriority
对象的相对成本,由 CacheItemPriority 枚举表示。缓存在退出对象时使用该值;具有较低成本的对象在具有较高成本的对象之前被从缓存移除。
- onRemoveCallback
- 类型:System.Web.Caching.CacheItemRemovedCallback
在从缓存中移除对象时所调用的委托(如果提供)。当从缓存中删除应用程序的对象时,可使用它来通知应用程序。
返回值
类型:System.Object
备注
如果 Cache 中已保存了具有相同 key 参数的项,则对此方法的调用将失败。若要使用相同的 key 参数覆盖现有的 Cache 项,请使用 Insert 方法。
无法同时设置 absoluteExpiration 和 slidingExpiration 参数。如果要让缓存项在特定时间到期,可将 absoluteExpiration 参数设置为特定时间,并将 slidingExpiration 参数设置为 NoSlidingExpiration。
如果要让缓存项在最后一次访问该项后的某段时间之后到期,可将 slidingExpiration 参数设置为到期间隔,并将 absoluteExpiration 参数设置为 NoAbsoluteExpiration。
此段转载自MSDN
具体的怎样添加这种缓存了,一般情况我会在母版页中Init事件或Load事件中添加缓存,因为这样可以保证引用程序从一开始执行就可以将需要频繁使用的对象缓存起来了。
protected void Page_Load(object sender, EventArgs e)
{
Cache.Add("key", //需要添加到Cache中的键
new { value="添加值"}, //对应的值
null, //缓存依赖项。
DateTime.Now.AddMinutes(1),//固定缓存时间
System.Web.Caching.Cache.NoSlidingExpiration, //可到延时缓存时间,
System.Web.Caching.CacheItemPriority.NotRemovable, //缓存中的优先级。
new System.Web.Caching.CacheItemRemovedCallback(OnMoveCacheBack));//移除时调用的回调函数
}
public void OnMoveCacheBack(string key, object value, System.Web.Caching.CacheItemRemovedReason reason)
{
if (Cache[key] != null)
{
Cache.Remove(key);
}
Cache.Add("key", //需要添加到Cache中的键
new { value = "更新值" }, //对应的值
null, //缓存依赖项。
DateTime.Now.AddMinutes(1),//固定缓存时间
System.Web.Caching.Cache.NoSlidingExpiration, //可到延时缓存时间,
System.Web.Caching.CacheItemPriority.NotRemovable, //缓存中的优先级。
new System.Web.Caching.CacheItemRemovedCallback(OnMoveCacheBack));//移除时调用的回调函数
}
参数的具体使用上一定要注意三点,
第一就是缓存的依赖项一定要指定为null。
第二固定到期缓存时间不能和可到延时缓存时间同时指定时间,实现我说的定期更换数据的,当然就要使用固定到期缓存时间了。
第三就是该缓存的优先级了,这个也比较关键,一定要指定为System.Web.Caching.CacheItemPriority.NotRemovable枚举值,这样才不会被自动收回,但是一定要注意该缓存的大小。
asp.net,Cache缓存
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】