ฉันถือว่ารหัสนี้มีปัญหาการเกิดพร้อมกัน:
const string CacheKey = "CacheKey";
static string GetCachedData()
{
    string expensiveString =null;
    if (MemoryCache.Default.Contains(CacheKey))
    {
        expensiveString = MemoryCache.Default[CacheKey] as string;
    }
    else
    {
        CacheItemPolicy cip = new CacheItemPolicy()
        {
            AbsoluteExpiration = new DateTimeOffset(DateTime.Now.AddMinutes(20))
        };
        expensiveString = SomeHeavyAndExpensiveCalculation();
        MemoryCache.Default.Set(CacheKey, expensiveString, cip);
    }
    return expensiveString;
}สาเหตุของปัญหาการเกิดพร้อมกันคือหลายเธรดสามารถรับคีย์ว่างจากนั้นพยายามแทรกข้อมูลลงในแคช
วิธีใดเป็นวิธีที่สั้นและสะอาดที่สุดในการพิสูจน์รหัสพร้อมกันนี้ ฉันชอบทำตามรูปแบบที่ดีในโค้ดที่เกี่ยวข้องกับแคชของฉัน ลิงก์ไปยังบทความออนไลน์จะช่วยได้มาก
UPDATE:
ฉันคิดรหัสนี้ตามคำตอบของ @Scott Chamberlain ใครสามารถพบปัญหาเกี่ยวกับประสิทธิภาพหรือการทำงานพร้อมกันนี้ได้หรือไม่? หากได้ผลก็จะช่วยประหยัดโค้ดและข้อผิดพลาดจำนวนมาก
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Runtime.Caching;
namespace CachePoc
{
    class Program
    {
        static object everoneUseThisLockObject4CacheXYZ = new object();
        const string CacheXYZ = "CacheXYZ";
        static object everoneUseThisLockObject4CacheABC = new object();
        const string CacheABC = "CacheABC";
        static void Main(string[] args)
        {
            string xyzData = MemoryCacheHelper.GetCachedData<string>(CacheXYZ, everoneUseThisLockObject4CacheXYZ, 20, SomeHeavyAndExpensiveXYZCalculation);
            string abcData = MemoryCacheHelper.GetCachedData<string>(CacheABC, everoneUseThisLockObject4CacheXYZ, 20, SomeHeavyAndExpensiveXYZCalculation);
        }
        private static string SomeHeavyAndExpensiveXYZCalculation() {return "Expensive";}
        private static string SomeHeavyAndExpensiveABCCalculation() {return "Expensive";}
        public static class MemoryCacheHelper
        {
            public static T GetCachedData<T>(string cacheKey, object cacheLock, int cacheTimePolicyMinutes, Func<T> GetData)
                where T : class
            {
                //Returns null if the string does not exist, prevents a race condition where the cache invalidates between the contains check and the retreival.
                T cachedData = MemoryCache.Default.Get(cacheKey, null) as T;
                if (cachedData != null)
                {
                    return cachedData;
                }
                lock (cacheLock)
                {
                    //Check to see if anyone wrote to the cache while we where waiting our turn to write the new value.
                    cachedData = MemoryCache.Default.Get(cacheKey, null) as T;
                    if (cachedData != null)
                    {
                        return cachedData;
                    }
                    //The value still did not exist so we now write it in to the cache.
                    CacheItemPolicy cip = new CacheItemPolicy()
                    {
                        AbsoluteExpiration = new DateTimeOffset(DateTime.Now.AddMinutes(cacheTimePolicyMinutes))
                    };
                    cachedData = GetData();
                    MemoryCache.Default.Set(cacheKey, cachedData, cip);
                    return cachedData;
                }
            }
        }
    }
}Dictionary<string, object>ที่คีย์นั้นเป็นคีย์เดียวกับที่คุณใช้ในของคุณMemoryCacheและอ็อบเจ็กต์ในพจนานุกรมเป็นเพียงพื้นฐานที่Objectคุณล็อคไว้ อย่างไรก็ตามตามที่กล่าวไว้ฉันขอแนะนำให้คุณอ่านคำตอบของจอนฮันนา หากไม่มีการกำหนดโปรไฟล์ที่เหมาะสมคุณอาจทำให้โปรแกรมของคุณช้าลงด้วยการล็อกมากกว่าการปล่อยให้SomeHeavyAndExpensiveCalculation()รันสองอินสแตนซ์และมีผลลัพธ์เดียว
                
ReaderWriterLockSlim?