.NET Core2.0小技巧之MemoryCache问题修复解决的方法(图)

这篇文章主要给大家介绍了关于.net core 2.0迁移小技巧之memorycache问题修复解决的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。

前言

大家应该都知道,对于传统的.NET Framework项目而言,System.Runtime.Caching命名空间是常用的工具了,其中MemoryCache类则常被用于实现内存缓存。

.NET Core 2.0暂时还不支持System.Runtime.Caching dll,这也就意味着MemoryCache相关代码不再起作用了。

但是好消息是,我们可以使用.NET Core 2.0的新API实现内存缓存功能,简单修改代码,解决不兼容问题。下面话不多说了,来一起看看详细的介绍吧。

解决方案

1.将旧代码导入项目中,如下:

using System;using System.Runtime.Caching;namespace TestWebApp.Service{ public class MemoryCacheService {  static ObjectCache cache = MemoryCache.Default;  ///   /// 获取缓存值  ///   ///   ///   private object GetCacheValue(string key)  {   if (key != null && cache.Contains(key))   {    return cache[key];   }   return default(object);  }  ///   /// 添加缓存内容  ///   ///   ///   public static void SetChacheValue(string key, object value)  {   if (key != null)   {    CacheItemPolicy policy = new CacheItemPolicy    {     SlidingExpiration = TimeSpan.FromHours(1)         };    cache.Set(key, value, policy);   }  } }}

登录后复制

导入后你会发现VS会提示无法找到System.Runtime.Caching命名空间,原有的代码无法直接编译使用。

.NET Core2.0小技巧之MemoryCache问题修复解决的方法(图)

2.添加对Microsoft.Extensions.Caching.Memory命名空间的引用,它提供了.NET Core默认实现的MemoryCache类,以及全新的内存缓存API

using Microsoft.Extensions.Caching.Memory;

登录后复制

3.改写代码,使用新的API实现内存缓存功能

初始化缓存对象方式改写前:

static ObjectCache cache = MemoryCache.Default;

登录后复制

初始化缓存对象方式改写后:

static MemoryCache cache = new MemoryCache(new MemoryCacheOptions());

登录后复制

读取内存缓存值方式变化:

private object GetCacheValue(string key){ if (key != null && cache.Contains(key)) {  return cache[key]; } return default(object);}

登录后复制

改写后:

private object GetCacheValue(string key){ object val = null; if (key != null && cache.TryGetValue(key, out val)) {  return val; } else {  return default(object); }}

登录后复制

设定内存缓存内容方式变化:

public static void SetChacheValue(string key, object value){ if (key != null) {  CacheItemPolicy policy = new CacheItemPolicy  {   SlidingExpiration = TimeSpan.FromHours(1)  };  cache.Set(key, value, policy); }}

登录后复制

修改后:

public static void SetChacheValue(string key, object value){ if (key != null) {  cache.Set(key, value, new MemoryCacheEntryOptions  {   SlidingExpiration = TimeSpan.FromHours(1)  }); }}

登录后复制

结论

在使用了Microsoft.Extensions.Caching.Memory下的新API改写了旧代码后,你会发现原有的各种内存缓存超时策略全都是有对应新API的,包括AbsoluteExpiration, SlidingExpiration等等。

所以我们还是可以很轻松的使用.NET Core新API简单改动下下就能重用现有绝大部分旧代码,将其迁移过来继续起作用。

迁移后的完整代码如下:

using Microsoft.Extensions.Caching.Memory;using System;namespace TestMemoryCacheWebApp.Services{ public class MemoryCacheService {  static MemoryCache cache = new MemoryCache(new MemoryCacheOptions());  ///   /// 获取缓存值  ///   ///   ///   private object GetCacheValue(string key)  {   object val = null;   if (key != null && cache.TryGetValue(key, out val))   {    return val;   }   else   {    return default(object);   }  }  ///   /// 添加缓存内容  ///   ///   ///   public static void SetChacheValue(string key, object value)  {   if (key != null)   {    cache.Set(key, value, new MemoryCacheEntryOptions    {     SlidingExpiration = TimeSpan.FromHours(1)    });   }  } }}

登录后复制

总结

以上就是.NET Core2.0小技巧之MemoryCache问题修复解决的方法(图)的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2438282.html

(0)
上一篇 2025年3月3日 11:36:39
下一篇 2025年2月26日 08:09:27

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 比较C#中值类型和引用类型的区别

    clr支持两种类型:值类型和引用类型,看起来fcl的大多数类型是引用类型,但用的最多的还是值类型。引用类型总是从托管堆中分配,在用new操作符实例一个对象,返回对象内存地址存放在一个变量中。在使用引用类型时要了解其四个心理因素:      …

    编程技术 2025年3月3日
    200
  • 介绍C#中的堆和栈

    1、什么是堆?     堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据对象;   堆的特征:     1、堆里面的内存能够以任意顺序存入和移除;     2、不能显示地删除程序在堆里面保存的数据;     3、靠clr的自动…

    编程技术 2025年3月3日
    200
  • C#制作ActiveX控件中如何调用海康SDK的问题解决

      这个事情就是一个坑,耽误了两周时间,之前并没有做过activex这玩意,现在客户需求如此,只能说是在网上看着教程做了。   事情是这样的,有一台海康威视的摄像头,客户需要一个ActiveX控件嵌入到网页中,通过点击按钮开始录制和结束录制…

    2025年3月3日 编程技术
    200
  • C#中使用反射以及特性简化的实例代码

    假设现在有一个学生类(Student)                                     {  { name =                    Age { ;                     Addre…

    2025年3月3日
    200
  • C#中关于静态与非静态方法的区别介绍

    静态方法和非静态方法的区别:   1.静态方法不需要类实例化就可以调用,反之非静态方法需要实例化后才能调用;   2.静态方法只能访问静态成员和方法,非静态方法都可以访问;   3.静态方法不能标记为override,导致派生类不能重写,但…

    2025年3月3日
    200
  • C#中匿名对象与var以及动态类型 dynamic的详解

    随着c#的发展,该语言内容不断丰富,开发变得更加方便快捷,c# 的锋利尽显无疑。c# 语言从诞生起就是强类型语言,这一性质到今天不曾改变,我想以后也不会变。既然是强类型语言,那编写任一程序均要求满足下面的基本条件: 1、变量声明必须指明其类…

    2025年3月3日
    200
  • 比较C#和JAVA中面向对象语法的区别

    面向对象是一种开发思想,最应该记住的一句话是万物皆对象。为了让程序更好的被理解和编写,把现实生活中描述事物的方式和思路融合进入,就成了面向对象的思想。把生活中的事物融合进程序中那么就需要描述,描述分为特征和行为两方面,而不同类别的对象特征和…

    编程技术 2025年3月3日
    200
  • C#/.NET易错的几点

    1 及时释放资源      clr托管环境扮演了垃圾回收的角色,所以你不需要显式释放已创建对象所占用的内存。但这不意味着你可以忽略所有的使用过的对象。许多对象封装了其 他类型的系统资源(例如,磁盘文件,数据连接,网络端口)。保持这些资源的使…

    编程技术 2025年3月3日
    200
  • 介绍C#中的接口

    对于很多初学者来说是个很容易迷糊的东西,使用起来很简单,无非就是定义接口,接口里面包含一些属性、索引器、事件和一些没有修饰符的方法,也没有方法的具体实现代码;然后在类中继承该接口,实现该接口中的所有属性、索引器、事件和方法的具体实现的代码(…

    编程技术 2025年3月3日
    200
  • 有关C#工厂模式简单讲解

    一、 简单工厂(simple factory)模式simple factory模式根据提供给它的数据,返回几个可能类中的一个类的实例。通常它返回的类都有一个公共的父类和公共的方法。 simple factory模式实际上不是gof 23个设…

    编程技术 2025年3月3日
    200

发表回复

登录后才能评论