LRU Cache的标准实现

时间:2014-09-22 09:13:11

标签: ios swift lru

我正在使用Swift构建应用程序,我想在我的应用程序中使用LRU Cache。我在Swift中实现了一个简单的LRUCache<K: Hashable, V>,但后来我发现因为它已经附带了Dictionary和Array集合,所以我可能会错过一个更好的原生选项。

我已经检查了文档和其他问题,但无法找到相关内容。

所以我的问题是:Swift是否配有LRUCache?如果是,如何使用它,如果它没有:我可以使用ObjectiveC版本并仍然保持我的Swift类型安全吗?

5 个答案:

答案 0 :(得分:7)

包装NSCache(对于类型约束)并不是那么辛苦。

struct LRUCache<K:AnyObject, V:AnyObject> {

    private let _cache = NSCache()

    var countLimit:Int {
        get {
            return _cache.countLimit
        }
        nonmutating set(countLimit) {
            _cache.countLimit = countLimit
        }
    }
    subscript(key:K!) -> V? {
        get {
            let obj:AnyObject? = _cache.objectForKey(key)
            return obj as V?
        }
        nonmutating set(obj) {
            if(obj == nil) {
                _cache.removeObjectForKey(key)
            }
            else {
                _cache.setObject(obj!, forKey: key)
            }
        }
    }
}

let cache = LRUCache<NSString, NSString>()
cache.countLimit = 3
cache["key1"] = "val1"
cache["key2"] = "val2"
cache["key3"] = "val3"
cache["key4"] = "val4"
cache["key5"] = "val5"
let val3 = cache["key3"]
cache["key6"] = "val6"

println((
    cache["key1"],
    cache["key2"],
    cache["key3"],
    cache["key4"],
    cache["key5"],
    cache["key6"]
))

结果:

(nil, nil, Optional(val3), nil, Optional(val5), Optional(val6))

答案 1 :(得分:2)

你可以使用HanekeSwift,这是一个用Swift编写的漂亮的通用缓存库。

答案 2 :(得分:1)

在Swift主库中没有LRUCache的标准实现,在(Core)Foundation这样的框架中也没有。

答案 3 :(得分:0)

你可以使用结合了NSArray和NSSet的NSOrderedSet作为开始;从中创建LRU缓存非常简单。或者对于许多用途,您可以使用NSCache。

答案 4 :(得分:0)

在GitHub上看看SwiftlyLRU,它是一个纯粹的Swift实现。时间:O(1),空格:O(1),它假设没有冲突到内部哈希表中,并且是一个单个文件可以拖入目标项目。

https://github.com/justinmfischer/SwiftlyLRU