.NET框架中的缓存

简介:
缓存使得你可以快速的获取内存中存储的数据。当再次访问数据的时候,应用从缓存中获取数据,而不是从数据的原始源获取。这么做可以提高性能和扩展性。另外,当数据源临时不可用的时候,缓存使得数据还是可用的。
 
你可以用.NET提供的缓存功能提高应用的性能和扩展性,缓存功能可以在windows客户端应用中使用,也可以在ASP.NET这种服务端应用中使用。
 

Note

在.NET Framework3.5和更早的版本中,ASP.NET提供了一个内存缓存的实现,放在System.Web.Caching命名空间下。所以在之前版本的.NET框架中,缓存只能通过System.Web命名空间获取,因此需要依赖一个ASP.NET类。在.NET Framwork4中,在System.Runtime.Caching命名空间下的缓存接口,Web应用和非Web应用都可以使用。

 
Caching Data
你可以使用System.Runtime.Caching命名空间下的类缓存数据。提供了下面的功能:
提供了一些抽象的类型,你可以继承这些抽象的类型,实现自己的缓存。
一个具体的实现好的内存缓存。
 
抽象基类提供了下面的功能:
  • 创建并管理缓存。
  • 指定过期和收回。
  • 在缓存信息改变的时候触发事件。
 
MemoryCache类是一个实现ObjectCache类的内存缓存,你可以用它来完成大部分的工作。
 
MemoryCache类的原型定义在System.Web.Caching空间中的ASP.NET缓存对象,因此,内部的缓存逻辑和早期的ASP.NET提供的缓存逻辑很相似。
 
在ASP.NET应用中使用缓存
使用System.Runtime.Caching中提供的缓存类可以给ASP.NET应用提供缓存功能。
 

Note 

如果你的ASP.NET应用是以.NET 3.5或者更早的版本为基础,你必须使用System.Web.Caching空间下的缓存类。

 
如果你是开发一个新的应用,推荐使用MemoryCache类。因为System.Runtime.Caching空间提供的接口和System.Web.Caching空间提供的接口很相似,如果你使用过早期版本的ASP.NET的话,你会感觉很亲切。
 
输出缓存
需要手动缓存应用中的数据,你可以在ASP.NET中使用MemoryCache类。ASP.NET也支持输出缓存,在内存中存储已经生成的页面、控件和http响应。你可以在ASP.NET页面中配置输出缓存,也可以在web.config中配置。
 
 
 
ASP.NET也允许你通过创建自定义输出缓存provider来扩展输出缓存。在自定义的provider中,你可以使用其他存储设备,例如:磁盘,云存储,分布式缓存,来存储输出缓存的内容。
创建自定义provider,你需要继承OutputCacheProvider类,并且在web.config中配置使用你自定义的provider。
 
扩展.NET Framework中的缓存
.NET Framework中的缓存被设计成可扩展的。ObjectCache类使得你可以创建自己的缓存实现。这个类提供了一些所有托管应用,例如:windows froms,wpf,wcp,都可用的成员。你可以创建自己的缓存,提供一个不同的存储机制,或者是你想要更小粒度的控制缓存的操作。
 
可以通过下面的方式实现一个自定义缓存:
 



本文转自 virusswb 51CTO博客,原文链接:http://blog.51cto.com/virusswb/1096632,如需转载请自行联系原作者
目录
相关文章
|
5月前
|
存储 缓存 NoSQL
Spring Cache缓存框架
Spring Cache是Spring体系下的标准化缓存框架,支持多种缓存(如Redis、EhCache、Caffeine),可独立或组合使用。其优势包括平滑迁移、注解与编程两种使用方式,以及高度解耦和灵活管理。通过动态代理实现缓存操作,适用于不同业务场景。
446 0
|
缓存 NoSQL Java
什么是缓存?如何在 Spring Boot 中使用缓存框架
什么是缓存?如何在 Spring Boot 中使用缓存框架
789 0
|
6月前
|
存储 缓存
.NET 6中Startup.cs文件注入本地缓存策略与服务生命周期管理实践:AddTransient, AddScoped, AddSingleton。
记住,选择正确的服务生命周期并妥善管理它们是至关重要的,因为它们直接影响你的应用程序的性能和行为。就像一个成功的建筑工地,工具箱如果整理得当,工具选择和使用得当,工地的整体效率将会大大提高。
238 0
|
9月前
|
缓存 NoSQL Java
Redis应用—8.相关的缓存框架
本文介绍了Ehcache和Guava Cache两个缓存框架及其使用方法,以及如何自定义缓存。主要内容包括:Ehcache缓存框架、Guava Cache缓存框架、自定义缓存。总结:Ehcache适合用作本地缓存或与Redis结合使用,Guava Cache则提供了更灵活的缓存管理和更高的并发性能。自定义缓存可以根据具体需求选择不同的数据结构和引用类型来实现特定的缓存策略。
585 16
Redis应用—8.相关的缓存框架
|
11月前
|
C# Android开发 iOS开发
2025年全面的.NET跨平台应用框架推荐
2025年全面的.NET跨平台应用框架推荐
473 23
|
12月前
|
存储 缓存 自然语言处理
SCOPE:面向大语言模型长序列生成的双阶段KV缓存优化框架
KV缓存是大语言模型(LLM)处理长文本的关键性能瓶颈,现有研究多聚焦于预填充阶段优化,忽视了解码阶段的重要性。本文提出SCOPE框架,通过分离预填充与解码阶段的KV缓存策略,实现高效管理。SCOPE保留预填充阶段的关键信息,并在解码阶段引入滑动窗口等策略,确保重要特征的有效选取。实验表明,SCOPE仅用35%原始内存即可达到接近完整缓存的性能水平,显著提升了长文本生成任务的效率和准确性。
608 3
SCOPE:面向大语言模型长序列生成的双阶段KV缓存优化框架
|
12月前
|
消息中间件 开发框架 监控
NET任务调度框架Hangfire使用指南
Hangfire 是一个用于 .NET 应用程序的开源任务调度框架,支持长时间运行任务、定时任务等。通过简单的安装配置,即可将任务从主线程分离,提升应用性能。支持多种数据库,提供丰富的任务类型如立即执行、延迟执行和周期性任务,并有可视化管理界面 Hangfire Dashboard。还支持安全性配置及扩展插件,如 Hangfire.HttpJob,适合各种复杂场景下的任务调度需求。
1135 1
NET任务调度框架Hangfire使用指南
|
12月前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
343 5
|
开发框架 安全 .NET
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱
在数字化时代,.NET 技术凭借跨平台兼容性、丰富的开发工具和框架、高效的性能及强大的安全稳定性,成为软件开发的重要支柱。它不仅加速了应用开发进程,提升了开发质量和可靠性,还促进了创新和业务发展,培养了专业人才和技术社区,为软件开发和数字化转型做出了重要贡献。
292 5
|
传感器 人工智能 供应链
.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。
本文深入探讨了.NET开发技术在数字化时代的创新作用,从高效的开发环境、强大的性能表现、丰富的库和框架资源等方面揭示了其关键优势。通过企业级应用、Web应用及移动应用的创新案例,展示了.NET在各领域的广泛应用和巨大潜力。展望未来,.NET将与新兴技术深度融合,拓展跨平台开发,推动云原生应用发展,持续创新。
163 4