Cache、它和Redis区别是什么???

前言:今天在博客园看到大佬在用Cache,非常不懂,原来它是搞缓存的,原来我只知道Redis是搞这个的,才知道有这个玩腻。

  那它们的区别是什么呢?? 区别: redis是分布式缓存,是将数据随机分配到不同服务器的,catch属于单机缓存,只能本机访问。

那Cache是如何工作的呢?

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

如何操作Cache??

创建:在DotNet环境下通过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”]来访问它。

最后附大佬封装好的帮助类一份:

C#/CacheHelper:

为此我们测试以下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public List<string> GetCompanyList()
       {
           var cache = CacheHelper.GetCache("Company_List");
           if (cache == null)//如果不存在
           {
               //var queryCompany = _Project_BLL_GetCompanyList;
               var queryCompany = new List<string>()
               {
                   "Zara博客工作室","中国网银","博客园"
               };
               CacheHelper.SetCache("companyData",queryCompany);//添加缓存
               return queryCompany.ToList();
           }
           return (List<string>)cache; //如果有的话就直接返回了
       }
posted @   ZaraNet  阅读(1330)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示