首頁  >  文章  >  後端開發  >  MemoryCache問題修復的解決方法

MemoryCache問題修復的解決方法

巴扎黑
巴扎黑原創
2017-09-01 14:32:162954瀏覽

這篇文章主要為大家介紹了關於.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;
  /// <summary>
  /// 获取缓存值
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  private object GetCacheValue(string key)
  {
   if (key != null && cache.Contains(key))
   {
    return cache[key];
   }
   return default(object);
  }
  /// <summary>
  /// 添加缓存内容
  /// </summary>
  /// <param name="key"></param>
  /// <param name="value"></param>
  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命名空間,原有的程式碼無法直接編譯使用。

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());
  /// <summary>
  /// 获取缓存值
  /// </summary>
  /// <param name="key"></param>
  /// <returns></returns>
  private object GetCacheValue(string key)
  {
   object val = null;
   if (key != null && cache.TryGetValue(key, out val))
   {

    return val;
   }
   else
   {
    return default(object);
   }
  }
  /// <summary>
  /// 添加缓存内容
  /// </summary>
  /// <param name="key"></param>
  /// <param name="value"></param>
  public static void SetChacheValue(string key, object value)
  {
   if (key != null)
   {
    cache.Set(key, value, new MemoryCacheEntryOptions
    {
     SlidingExpiration = TimeSpan.FromHours(1)
    });
   }
  }
 }
}

以上是MemoryCache問題修復的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn