您好,登錄后才能下訂單哦!
這篇文章主要介紹如何解決.NET Core 2.0遷移中的MemoryCache問(wèn)題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
對(duì)于傳統(tǒng)的.NET Framework項(xiàng)目而言,System.Runtime.Caching
命名空間是常用的工具了,其中MemoryCache類則常被用于實(shí)現(xiàn)內(nèi)存緩存。
.NET Core 2.0暫時(shí)還不支持System.Runtime.Caching dll,這也就意味著MemoryCache相關(guān)代碼不再起作用了。
但是好消息是,我們可以使用.NET Core 2.0的新API實(shí)現(xiàn)內(nèi)存緩存功能,簡(jiǎn)單修改代碼,解決不兼容問(wèn)題。
解決方案
1.將舊代碼導(dǎo)入項(xiàng)目中,如下:
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> /// 添加緩存內(nèi)容 /// </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); } } } }
導(dǎo)入后你會(huì)發(fā)現(xiàn)VS會(huì)提示無(wú)法找到System.Runtime.Caching
命名空間,原有的代碼無(wú)法直接編譯使用。
2.添加對(duì)Microsoft.Extensions.Caching.Memory
命名空間的引用,它提供了.NET Core默認(rèn)實(shí)現(xiàn)的MemoryCache類,以及全新的內(nèi)存緩存API
using Microsoft.Extensions.Caching.Memory;
3.改寫代碼,使用新的API實(shí)現(xiàn)內(nèi)存緩存功能
初始化緩存對(duì)象方式改寫前:
static ObjectCache cache = MemoryCache.Default;
初始化緩存對(duì)象方式改寫后:
static MemoryCache cache = new MemoryCache(new MemoryCacheOptions());
讀取內(nèi)存緩存值方式變化:
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); } }
設(shè)定內(nèi)存緩存內(nèi)容方式變化:
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) }); } }
結(jié)論
在使用了Microsoft.Extensions.Caching.Memory
下的新API改寫了舊代碼后,你會(huì)發(fā)現(xiàn)原有的各種內(nèi)存緩存超時(shí)策略全都是有對(duì)應(yīng)新API的,包括AbsoluteExpiration, SlidingExpiration等等。
所以我們還是可以很輕松的使用.NET Core新API簡(jiǎn)單改動(dòng)下下就能重用現(xiàn)有絕大部分舊代碼,將其遷移過(guò)來(lái)繼續(xù)起作用。
遷移后的完整代碼如下:
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> /// 添加緩存內(nèi)容 /// </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) }); } } } }
以上是“如何解決.NET Core 2.0遷移中的MemoryCache問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。