我正在使用Swift构建应用程序,我想在我的应用程序中使用LRU Cache。我在Swift中实现了一个简单的LRUCache<K: Hashable, V>
,但后来我发现因为它已经附带了Dictionary和Array集合,所以我可能会错过一个更好的原生选项。
我已经检查了文档和其他问题,但无法找到相关内容。
所以我的问题是:Swift是否配有LRUCache?如果是,如何使用它,如果它没有:我可以使用ObjectiveC版本并仍然保持我的Swift类型安全吗?
答案 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),它假设没有冲突到内部哈希表中,并且是一个单个文件可以拖入目标项目。