欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解C#中Helper類的使用

 更新時(shí)間:2022年04月22日 09:19:47   作者:CoolDog  
項(xiàng)目中用戶頻繁訪問(wèn)數(shù)據(jù)庫(kù)會(huì)導(dǎo)致程序的卡頓,甚至堵塞。使用緩存可以有效的降低用戶訪問(wèn)數(shù)據(jù)庫(kù)的頻次,有效的減少并發(fā)的壓力。而helper類對(duì)緩存有了封裝,本文展示了封裝的示例代碼,需要的可以參考一下

使用背景

項(xiàng)目中用戶頻繁訪問(wèn)數(shù)據(jù)庫(kù)會(huì)導(dǎo)致程序的卡頓,甚至堵塞。使用緩存可以有效的降低用戶訪問(wèn)數(shù)據(jù)庫(kù)的頻次,有效的減少并發(fā)的壓力。保護(hù)后端真實(shí)的服務(wù)器。

對(duì)于開(kāi)發(fā)人員需要方便調(diào)用,所以本文提供了helper類對(duì)緩存有了封裝。分了三個(gè)Cache,SystemCache,RedisCache(默認(rèn)緩存,系統(tǒng)緩存,Redis緩存)。話不多說(shuō),開(kāi)擼!

使用方法

1.引用CSRedisCore

可以看到,csredis支持.net40/.net45/.netstandard平臺(tái),還是比較友好的。

2.增加helper類代碼

CacheHelper.cs

/// <summary>
    /// 緩存幫助類
    /// </summary>
    public class CacheHelper
    {
        /// <summary>
        /// 靜態(tài)構(gòu)造函數(shù),初始化緩存類型
        /// </summary>
        static CacheHelper()
        {
            SystemCache = new SystemCache();

       if(true)       //項(xiàng)目全局變量類,可自行定義
           // if (GlobalSwitch.OpenRedisCache)
            {
                try
                {
                    RedisCache = new RedisCache(GlobalSwitch.RedisConfig);
                }
                catch
                {

                }
            }

            switch (GlobalSwitch.CacheType)
            {
                case CacheType.SystemCache:Cache = SystemCache;break;
                case CacheType.RedisCache:Cache = RedisCache;break;
                default:throw new Exception("請(qǐng)指定緩存類型!");
            }
        }

        /// <summary>
        /// 默認(rèn)緩存
        /// </summary>
        public static ICache Cache { get; }

        /// <summary>
        /// 系統(tǒng)緩存
        /// </summary>
        public static ICache SystemCache { get; }

        /// <summary>
        /// Redis緩存
        /// </summary>
        public static ICache RedisCache { get; }
    }

ICache.cs

/// <summary>
    /// 緩存操作接口類
    /// </summary>
    public interface ICache
    {
        #region 設(shè)置緩存

        /// <summary>
        /// 設(shè)置緩存
        /// </summary>
        /// <param name="key">主鍵</param>
        /// <param name="value">值</param>
        void SetCache(string key, object value);

        /// <summary>
        /// 設(shè)置緩存
        /// 注:默認(rèn)過(guò)期類型為絕對(duì)過(guò)期
        /// </summary>
        /// <param name="key">主鍵</param>
        /// <param name="value">值</param>
        /// <param name="timeout">過(guò)期時(shí)間間隔</param>
        void SetCache(string key, object value, TimeSpan timeout);

        /// <summary>
        /// 設(shè)置緩存
        /// 注:默認(rèn)過(guò)期類型為絕對(duì)過(guò)期
        /// </summary>
        /// <param name="key">主鍵</param>
        /// <param name="value">值</param>
        /// <param name="timeout">過(guò)期時(shí)間間隔</param>
        /// <param name="expireType">過(guò)期類型</param>
        void SetCache(string key, object value, TimeSpan timeout, ExpireType expireType);

        /// <summary>
        /// 設(shè)置鍵失效時(shí)間
        /// </summary>
        /// <param name="key">鍵值</param>
        /// <param name="expire">從現(xiàn)在起時(shí)間間隔</param>
        void SetKeyExpire(string key, TimeSpan expire);

        #endregion

        #region 獲取緩存

        /// <summary>
        /// 獲取緩存
        /// </summary>
        /// <param name="key">主鍵</param>
        object GetCache(string key);

        /// <summary>
        /// 獲取緩存
        /// </summary>
        /// <param name="key">主鍵</param>
        /// <typeparam name="T">數(shù)據(jù)類型</typeparam>
        T GetCache<T>(string key) where T : class;

        /// <summary>
        /// 是否存在鍵值
        /// </summary>
        /// <param name="key">主鍵</param>
        /// <returns></returns>
        bool ContainsKey(string key);

        #endregion

        #region 刪除緩存

        /// <summary>
        /// 清除緩存
        /// </summary>
        /// <param name="key">主鍵</param>
        void RemoveCache(string key);

        #endregion
    }

    #region 類型定義

    /// <summary>
    /// 值信息
    /// </summary>
    public struct ValueInfoEntry
    {
        public string Value { get; set; }
        public string TypeName { get; set; }
        public TimeSpan? ExpireTime { get; set; }
        public ExpireType? ExpireType { get; set; }
    }

    /// <summary>
    /// 過(guò)期類型
    /// </summary>
    public enum ExpireType
    {
        /// <summary>
        /// 絕對(duì)過(guò)期
        /// 注:即自創(chuàng)建一段時(shí)間后就過(guò)期
        /// </summary>
        Absolute,

        /// <summary>
        /// 相對(duì)過(guò)期
        /// 注:即該鍵未被訪問(wèn)后一段時(shí)間后過(guò)期,若此鍵一直被訪問(wèn)則過(guò)期時(shí)間自動(dòng)延長(zhǎng)
        /// </summary>
        Relative,
    }

    #endregion

RedisCache.cs

/// <summary>
    /// Redis緩存
    /// </summary>
    public class RedisCache : ICache
    {
        /// <summary>
        /// 構(gòu)造函數(shù)
        /// 注意:請(qǐng)以單例使用
        /// </summary>
        /// <param name="config">配置字符串</param>
        public RedisCache(string config)
        {
            _redisCLient = new CSRedisClient(config);
        }
        private CSRedisClient _redisCLient { get; }

        public bool ContainsKey(string key)
        {
            return _redisCLient.Exists(key);
        }

        public object GetCache(string key)
        {
            object value = null;
            var redisValue = _redisCLient.Get(key);
            if (redisValue.IsNullOrEmpty())
                return null;
            ValueInfoEntry valueEntry = redisValue.ToString().ToObject<ValueInfoEntry>();
            if (valueEntry.TypeName == typeof(string).AssemblyQualifiedName)
                value = valueEntry.Value;
            else
                value = valueEntry.Value.ToObject(Type.GetType(valueEntry.TypeName));

            if (valueEntry.ExpireTime != null && valueEntry.ExpireType == ExpireType.Relative)
                SetKeyExpire(key, valueEntry.ExpireTime.Value);

            return value;
        }

        public T GetCache<T>(string key) where T : class
        {
            return (T)GetCache(key);
        }

        public void SetKeyExpire(string key, TimeSpan expire)
        {
            _redisCLient.Expire(key, expire);
        }

        public void RemoveCache(string key)
        {
            _redisCLient.Del(key);
        }

        public void SetCache(string key, object value)
        {
            _SetCache(key, value, null, null);
        }

        public void SetCache(string key, object value, TimeSpan timeout)
        {
            _SetCache(key, value, timeout, ExpireType.Absolute);
        }

        public void SetCache(string key, object value, TimeSpan timeout, ExpireType expireType)
        {
            _SetCache(key, value, timeout, expireType);
        }

        private void _SetCache(string key, object value, TimeSpan? timeout, ExpireType? expireType)
        {
            string jsonStr = string.Empty;
            if (value is string)
                jsonStr = value as string;
            else
                jsonStr = value.ToJson();

            ValueInfoEntry entry = new ValueInfoEntry
            {
                Value = jsonStr,
                TypeName = value.GetType().AssemblyQualifiedName,
                ExpireTime = timeout,
                ExpireType = expireType
            };

            string theValue = entry.ToJson();
            if (timeout == null)
                _redisCLient.Set(key, theValue);
            else
                _redisCLient.Set(key, theValue, (int)timeout.Value.TotalSeconds);
        }
    }

SystemCache.cs

/// <summary>
    /// 系統(tǒng)緩存幫助類
    /// </summary>
    public class SystemCache : ICache
    {
        public object GetCache(string key)
        {
            return HttpRuntime.Cache[key];
        }

        public T GetCache<T>(string key) where T : class
        {
            return (T)HttpRuntime.Cache[key];
        }

        public bool ContainsKey(string key)
        {
            return GetCache(key) != null;
        }

        public void RemoveCache(string key)
        {
            HttpRuntime.Cache.Remove(key);
        }

        public void SetKeyExpire(string key, TimeSpan expire)
        {
            object value = GetCache(key);
            SetCache(key, value, expire);
        }

        public void SetCache(string key, object value)
        {
            _SetCache(key, value, null, null);
        }

        public void SetCache(string key, object value, TimeSpan timeout)
        {
            _SetCache(key, value, timeout, ExpireType.Absolute);
        }

        public void SetCache(string key, object value, TimeSpan timeout, ExpireType expireType)
        {
            _SetCache(key, value, timeout, expireType);
        }

        private void _SetCache(string key, object value, TimeSpan? timeout, ExpireType? expireType)
        {
            if (timeout == null)
                HttpRuntime.Cache[key] = value;
            else
            {
                if (expireType == ExpireType.Absolute)
                {
                    DateTime endTime = DateTime.Now.AddTicks(timeout.Value.Ticks);
                    HttpRuntime.Cache.Insert(key, value, null, endTime, Cache.NoSlidingExpiration);
                }
                else
                {
                    HttpRuntime.Cache.Insert(key, value, null, Cache.NoAbsoluteExpiration, timeout.Value);
                }
            }
        }
    }

3.使用

4.說(shuō)明

Redis 是一個(gè)開(kāi)源(BSD許可)的,內(nèi)存中的數(shù)據(jù)結(jié)構(gòu)存儲(chǔ)系統(tǒng),它可以用作數(shù)據(jù)庫(kù)、緩存和消息中間件?! ?/p>

它是基于高性能的Key-Value、并提供多種語(yǔ)言的 API的非關(guān)系型數(shù)據(jù)庫(kù)。不過(guò)與傳統(tǒng)數(shù)據(jù)庫(kù)不同的是 redis 的數(shù)據(jù)是存在內(nèi)存中的,所以存寫(xiě)速度非???。

它支持多種類型的數(shù)據(jù)結(jié)構(gòu),如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets)

結(jié)語(yǔ)

這里提供了helper類,主要是為了封裝緩存,使用起來(lái)更加方便。具體可以在其基礎(chǔ)上進(jìn)行擴(kuò)展。

到此這篇關(guān)于詳解C#中Helper類的使用的文章就介紹到這了,更多相關(guān)C# Helper類內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C# DI依賴注入的實(shí)現(xiàn)示例

    C# DI依賴注入的實(shí)現(xiàn)示例

    依賴注入是一種實(shí)現(xiàn)的方法,用于減少代碼之間的耦合,本文主要介紹了C# DI依賴注入的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣可以了解一下
    2023-12-12
  • PC藍(lán)牙通信C#代碼實(shí)現(xiàn)

    PC藍(lán)牙通信C#代碼實(shí)現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了PC藍(lán)牙通信C#代碼實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • C# ComboBox控件“設(shè)置 DataSource 屬性后無(wú)法修改項(xiàng)集合”的完美解決方法

    C# ComboBox控件“設(shè)置 DataSource 屬性后無(wú)法修改項(xiàng)集合”的完美解決方法

    這篇文章主要介紹了C# ComboBox控件“設(shè)置 DataSource 屬性后無(wú)法修改項(xiàng)集合”的解決方法,非常不錯(cuò)具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2016-11-11
  • C# WinForm實(shí)現(xiàn)自動(dòng)更新程序的方法詳解

    C# WinForm實(shí)現(xiàn)自動(dòng)更新程序的方法詳解

    這一篇就著重寫(xiě)一下客戶端的代碼,客戶端主要實(shí)現(xiàn)的有:?jiǎn)?dòng)后檢測(cè)本地的xml文件,然后發(fā)送到服務(wù)器獲取需要更新的文件以及版本列表,感興趣的小伙伴可以了解一下
    2022-10-10
  • 使用 C# 下載文件的多種方法小結(jié)

    使用 C# 下載文件的多種方法小結(jié)

    本文從最簡(jiǎn)單的下載方式開(kāi)始步步遞進(jìn),講述了文件下載過(guò)程中的常見(jiàn)問(wèn)題并給出了解決方案。并展示了如何使用多線程提升 HTTP 的下載速度以及調(diào)用 aria2 實(shí)現(xiàn)非 HTTP 協(xié)議的文件下載,對(duì)C# 下載文件相關(guān)知識(shí)感興趣的朋友一起看看吧
    2021-08-08
  • C#異步調(diào)用的好處和方法分享

    C#異步調(diào)用的好處和方法分享

    我們要明確,為什么要進(jìn)行異步回調(diào)?眾所周知,普通方法運(yùn)行,是單線程的,如果中途有大型操作(如:讀取大文件,大批量操作數(shù)據(jù)庫(kù),網(wǎng)絡(luò)傳輸?shù)龋?,都?huì)導(dǎo)致方法阻塞,表現(xiàn)在界面上就是,程序卡或者死掉,界面元素不動(dòng)了,不響應(yīng)了
    2012-04-04
  • C#中API調(diào)用的多種方法

    C#中API調(diào)用的多種方法

    今天通過(guò)本文給大家分享C#中API調(diào)用的多種方法,通過(guò)API進(jìn)行解析掃入的二維碼,實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2021-09-09
  • c#語(yǔ)言使用Unity粒子系統(tǒng)制作手雷爆炸

    c#語(yǔ)言使用Unity粒子系統(tǒng)制作手雷爆炸

    這篇文章主要為大家介紹了Unity的粒子系統(tǒng)由粒子發(fā)射器、粒子動(dòng)畫(huà)器、粒子渲染器組成,通過(guò)使用一或兩個(gè)紋理多次繪制,創(chuàng)造一個(gè)混沌的效果,通過(guò)復(fù)習(xí)粒子系統(tǒng)做一個(gè)手雷和實(shí)彈投擲現(xiàn)場(chǎng)
    2022-04-04
  • C#基礎(chǔ)入門(mén)之算法:交換

    C#基礎(chǔ)入門(mén)之算法:交換

    本文主要介紹了C#中算法:交換的相關(guān)知識(shí),具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • unity 鼠標(biāo)懸停事件操作

    unity 鼠標(biāo)懸停事件操作

    這篇文章主要介紹了unity 鼠標(biāo)懸停事件操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-04-04

最新評(píng)論