LRUCache c#

LRUCache是Least Recently Used
近日起码使用算法的缓存,是android提供的贰个缓存工具类。能够以两种排序形式来输出缓存,一种是按插入顺序输出,一种是按近日最少格局出口,近期应用的放在队首,使用功用低的,间隔时间最长的位于队尾。
上边是落成

using System;
using System.Collections.Generic;
namespace LY.Helper
{
public class LRUCache<T>
{
    private Dictionary<string, T> dict;
    private LinkedList<T> list;
    private int size = 0;
    private bool isSequence = false;

    public LRUCache(int sz):this(sz,false)
    {

    }

    public LRUCache(int sz, bool isSq)
    {
        isSequence = isSq;
        size = sz < 10 ? 10 : sz;
        dict = new Dictionary<string, T>(size);
        list = new LinkedList<T>();
    }


    public int Size
    {
        get { return size; }
        set { size = value < 10 ? 10 : value; }
    }

    public void Put(string key, T item)
    {
        T node;
        if(dict.TryGetValue(key, out node))
        {
            list.Remove(node);

            dict[key] = item;
            list.AddFirst(item);
        }
        else
        {
            if(list.Count == size)
                list.RemoveLast();
            dict[key] = item;
            list.AddFirst(item);
        }
    }

    public T Get(string key)
    {
        T node;
        if(dict.TryGetValue(key, out node))
        {
            list.Remove(node);
            list.AddFirst(node);
            return node;
        }
        return default(T);
    }

    public ICollection<T> Values
    {
        get
        {
            if (isSequence)
            {
                return dict.Values;
            }
            else
            {
                return list;
            }
        }
    }
}
}

 

构造函数中盛传缓存大小和输出缓存顺序。
澳门新葡新京,大家在调用Put方法时,当缓存长度超越大家构造函数中传来的轻重时,会将队尾的移除。将新传入的靶子放在队首。
咱俩从LRUCache中收获对象时,在Get方法中,会将对象移除,并置于队首。
下边大家来进展测验

澳门新葡新京 1澳门新葡新京 2

private void btnTest_Click(object sender, EventArgs e)
{
LRUCache<int> lruCache = new LRUCache<int>(10);
lruCache.Put("1", 1);
lruCache.Put("2", 2);
lruCache.Put("3", 3);
lruCache.Put("4", 4);
lruCache.Put("5", 5);
        lruCache.Get("2");
        lruCache.Get("3");

        Console.WriteLine("最近最少方式Test...");
        foreach (var item in lruCache.Values)
        {
            Console.WriteLine(item.ToString());
        }

        LRUCache<int> lruCache1 = new LRUCache<int>(10, true);
        lruCache1.Put("1", 1);
        lruCache1.Put("2", 2);
        lruCache1.Put("3", 3);
        lruCache1.Put("4", 4);
        lruCache1.Put("5", 5);

        lruCache1.Get("2");
        lruCache1.Get("3");

        Console.WriteLine("顺序方式Test...");
        foreach (var item in lruCache1.Values)
        {
            Console.WriteLine(item.ToString());
        }
    }

View Code

 

大家来看下输出结果

 

 

澳门新葡新京 3

相关文章