gpt4 book ai didi

c# - IDictionary 有 LRU 实现吗?

转载 作者:IT王子 更新时间:2023-10-29 04:17:44 26 4
gpt4 key购买 nike

我想实现一个简单的内存中 LRU 缓存系统,我正在考虑一个基于 IDictionary 实现的解决方案,它可以处理散列 LRU 机制。来自 Java,我有使用 LinkedHashMap 的经验,它可以很好地满足我的需要:我在任何地方都找不到适用于 .NET 的类似解决方案。

有没有人开发过或者有过这样的经历?

最佳答案

这是我们为我们拥有的网站开发的一个非常简单和快速的实现。

我们尽量改进代码,同时保持线程安全。我认为代码非常简单明了,但如果您需要一些解释或与如何使用它相关的指南,请不要犹豫,尽管询问。

namespace LRUCache
{
public class LRUCache<K,V>
{
private int capacity;
private Dictionary<K, LinkedListNode<LRUCacheItem<K, V>>> cacheMap = new Dictionary<K, LinkedListNode<LRUCacheItem<K, V>>>();
private LinkedList<LRUCacheItem<K, V>> lruList = new LinkedList<LRUCacheItem<K, V>>();

public LRUCache(int capacity)
{
this.capacity = capacity;
}

[MethodImpl(MethodImplOptions.Synchronized)]
public V get(K key)
{
LinkedListNode<LRUCacheItem<K, V>> node;
if (cacheMap.TryGetValue(key, out node))
{
V value = node.Value.value;
lruList.Remove(node);
lruList.AddLast(node);
return value;
}
return default(V);
}

[MethodImpl(MethodImplOptions.Synchronized)]
public void add(K key, V val)
{
if (cacheMap.TryGetValue(key, out var existingNode))
{
lruList.Remove(existingNode);
}
else if (cacheMap.Count >= capacity)
{
RemoveFirst();
}

LRUCacheItem<K, V> cacheItem = new LRUCacheItem<K, V>(key, val);
LinkedListNode<LRUCacheItem<K, V>> node = new LinkedListNode<LRUCacheItem<K, V>>(cacheItem);
lruList.AddLast(node);
// cacheMap.Add(key, node); - here's bug if try to add already existing value
cacheMap[key] = node;
}

private void RemoveFirst()
{
// Remove from LRUPriority
LinkedListNode<LRUCacheItem<K,V>> node = lruList.First;
lruList.RemoveFirst();

// Remove from cache
cacheMap.Remove(node.Value.key);
}
}

class LRUCacheItem<K,V>
{
public LRUCacheItem(K k, V v)
{
key = k;
value = v;
}
public K key;
public V value;
}
}

关于c# - IDictionary 有 LRU 实现吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/754233/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com