package main import( "fmt" ) type Node struct { Key string Val string Pre *Node Next *Node } type DLinkedList struct { Head *Node Tail *Node } func (self *DLinkedList) IsEmpty() bool { if self.Head == nil && self.Tail == nil { return true } else { return false } } func (self *DLinkedList) RemoveLast() { if self.Tail != nil { self.Remove(self.Tail) } } func (self *DLinkedList) Remove(n *Node){ if self.Tail == self.Head { self.Head = nil self.Tail = nil return } if n == self.Head { n.Next.Pre = nil self.Head = n.Next return } if n == self.Tail { n.Pre.Next = nil self.Tail = n.Pre return } n.Pre.Next = n.Next n.Next.Pre = n.Pre } func (self *DLinkedList) AddFirst(n *Node) { if self.Head == nil { self.Head = n self.Tail = n n.Pre = nil n.Next = nil return } n.Next = self.Head self.Head.Pre = n self.Head = n n.Pre = nil } type LRUCache struct { Cap int Size int HashMap map[string]*Node Cache *DLinkedList } func (self *LRUCache) Get(k string) string { if node,ok := self.HashMap[k]; ok { self.Cache.Remove(node) self.Cache.AddFirst(node) return node.Val } else { return "" } } func (self *LRUCache) Set(k,val string ) { if node,ok := self.HashMap[k];ok { self.Cache.Remove(node) node.Val = val self.Cache.AddFirst(node) } else { n := &Node{Key:k,Val:val} self.HashMap[k] = n self.Cache.AddFirst(n) self.Size = self.Size + 1 if self.Size > self.Cap { self.Size = self.Size - 1 delete(self.HashMap,self.Cache.Tail.Key) self.Cache.RemoveLast() } } } func main() { cache := new(LRUCache) cache.Cap = 3 cache.HashMap = make(map[string]*Node,0) cache.Cache = new(DLinkedList) cache.Set("allen","value") cache.Set("a","value") cache.Set("b","value") cache.Set("c","value") test := cache.Get("allen") fmt.Println(test) fmt.Println(cache.HashMap) fmt.Println(cache.Cache) fmt.Println(cache.Size) }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据密集型应用系统设计
Martin Kleppmann / 赵军平、李三平、吕云松、耿煜 / 中国电力出版社 / 2018-9-1 / 128
全书分为三大部分: 第一部分,主要讨论有关增强数据密集型应用系统所需的若干基本原则。首先开篇第1章即瞄准目标:可靠性、可扩展性与可维护性,如何认识这些问题以及如何达成目标。第2章我们比较了多种不同的数据模型和查询语言,讨论各自的适用场景。接下来第3章主要针对存储引擎,即数据库是如何安排磁盘结构从而提高检索效率。第4章转向数据编码(序列化)方面,包括常见模式的演化历程。 第二部分,我们将......一起来看看 《数据密集型应用系统设计》 这本书的介绍吧!