golang實(shí)現(xiàn)LRU算法

LRU緩存淘汰算法

LRU是最近最少使用策略的縮寫脉漏。

雙向鏈表實(shí)現(xiàn)LRU

將Cache的所有位置都用雙鏈表連接起來(lái)岭辣,當(dāng)一個(gè)位置被訪問(wèn)(get/put)之后,通過(guò)調(diào)整鏈表的指向匪蝙,將該位置調(diào)整到鏈表尾的位置吓著,新加入的Cache直接加到鏈表尾。

這樣歉井,在多次操作后柿祈,最近被訪問(wèn)(get/put)的,就會(huì)被向鏈表尾方向移動(dòng)哩至,而沒(méi)有訪問(wèn)的躏嚎,向鏈表前方移動(dòng),鏈表頭則表示最近最少使用的Cache菩貌。

package main

import (

"fmt"

)

type Node struct{

Key interface{}

Value interface{}

pre *Node

next *Node

}

type LRUCache struct {

limit int

HashMap map[interface{}]*Node

head *Node

end *Node

}

func(l *LRUCache)removeNode(node *Node)interface{}{

if node == l.end{

l.end = l.end.pre

l.end.next = nil

} else if node == l.head{

l.head = l.head.next

l.head.pre = nil

} else {

node.pre.next = node.next

node.next.pre = node.pre

}

return node.Key

}

func (l *LRUCache)addNode(node *Node){

if l.end != nil {

l.end.next = node

node.pre = l.end

node.next = nil

}

l.end = node

if l.head == nil {

l.head = node

}

}

func (l *LRUCache)refreshNode(node *Node){

if node == l.end{

return

}

l.removeNode(node) // 從鏈表中的任意位置移除原來(lái)的位置

l.addNode(node) // 添加到鏈表的尾部

}

// 構(gòu)造

func Constructor(capacity int)LRUCache{

lruCache := LRUCache{limit: capacity}

lruCache.HashMap = make(map[interface{}]*Node, capacity)

return lruCache

}

// 獲取

func (l *LRUCache)Get(key interface{})interface{}{

if v, ok := l.HashMap[key]; ok {

l.refreshNode(v)

return v.Value

} else {

return -1

}

}

func (l *LRUCache)Put(key, value interface{}){

if v, ok := l.HashMap[key]; !ok{

if len(l.HashMap) >= l.limit {

oldkey := l.removeNode(l.head)

delete(l.HashMap, oldkey)

}

node := Node{Key:key, Value:value}

l.addNode(&node)

l.HashMap[key] = &node

} else {

v.Value = value

l.refreshNode(v)

}

}

func (l *LRUCache)getCache(){

for n := l.head; n != nil; n = n.next{

fmt.Println(n.Key, n.Value)

}

}

func main(){

cache := Constructor(3)

cache.Put(11, 1)

cache.Put(22, 2)

cache.Put(33, 3)

cache.Put(44, 4)

v := cache.Get(33)

fmt.Println(v)

fmt.Println("========== 獲取數(shù)據(jù)之后 ===============")

cache.getCache()

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末卢佣,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子箭阶,更是在濱河造成了極大的恐慌虚茶,老刑警劉巖戈鲁,帶你破解...
    沈念sama閱讀 218,682評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異嘹叫,居然都是意外死亡婆殿,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,277評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門待笑,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)鸣皂,“玉大人,你說(shuō)我怎么就攤上這事暮蹂∧欤” “怎么了?”我有些...
    開封第一講書人閱讀 165,083評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵仰泻,是天一觀的道長(zhǎng)荆陆。 經(jīng)常有香客問(wèn)我,道長(zhǎng)集侯,這世上最難降的妖魔是什么被啼? 我笑而不...
    開封第一講書人閱讀 58,763評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮棠枉,結(jié)果婚禮上浓体,老公的妹妹穿的比我還像新娘。我一直安慰自己辈讶,他們只是感情好命浴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,785評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著贱除,像睡著了一般生闲。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上月幌,一...
    開封第一講書人閱讀 51,624評(píng)論 1 305
  • 那天碍讯,我揣著相機(jī)與錄音,去河邊找鬼扯躺。 笑死捉兴,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的录语。 我是一名探鬼主播轴术,決...
    沈念sama閱讀 40,358評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼钦无!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起盖袭,我...
    開封第一講書人閱讀 39,261評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤失暂,失蹤者是張志新(化名)和其女友劉穎彼宠,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體弟塞,經(jīng)...
    沈念sama閱讀 45,722評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡凭峡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了决记。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片摧冀。...
    茶點(diǎn)故事閱讀 40,030評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖系宫,靈堂內(nèi)的尸體忽然破棺而出索昂,到底是詐尸還是另有隱情,我是刑警寧澤扩借,帶...
    沈念sama閱讀 35,737評(píng)論 5 346
  • 正文 年R本政府宣布椒惨,位于F島的核電站,受9級(jí)特大地震影響潮罪,放射性物質(zhì)發(fā)生泄漏康谆。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,360評(píng)論 3 330
  • 文/蒙蒙 一嫉到、第九天 我趴在偏房一處隱蔽的房頂上張望沃暗。 院中可真熱鬧,春花似錦何恶、人聲如沸孽锥。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,941評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)忱叭。三九已至,卻和暖如春今艺,著一層夾襖步出監(jiān)牢的瞬間韵丑,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,057評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工虚缎, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留撵彻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,237評(píng)論 3 371
  • 正文 我出身青樓实牡,卻偏偏與公主長(zhǎng)得像陌僵,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子创坞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,976評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 緩存文件置換機(jī)制是計(jì)算機(jī)處理緩存存儲(chǔ)器的一種機(jī)制碗短。 計(jì)算機(jī)存儲(chǔ)器空間的大小固定,無(wú)法容納服務(wù)器上所有的文件题涨,所以當(dāng)...
    hwholiday閱讀 442評(píng)論 0 0
  • Python語(yǔ)言特性 1 Python的函數(shù)參數(shù)傳遞 看兩個(gè)如下例子偎谁,分析運(yùn)行結(jié)果: 代碼一: a = 1 def...
    伊森H閱讀 3,067評(píng)論 0 15
  • 什么是數(shù)組总滩? 數(shù)組簡(jiǎn)單來(lái)說(shuō)就是將所有的數(shù)據(jù)排成一排存放在系統(tǒng)分配的一個(gè)內(nèi)存塊上,通過(guò)使用特定元素的索引作為數(shù)組的下...
    啟明_b56f閱讀 914評(píng)論 0 0
  • 對(duì)于我們成年人來(lái)說(shuō)巡雨,早上起來(lái)拿著自己的杯子闰渔,喝上一杯水,這是很自然流暢的事情铐望。但對(duì)于嬰兒而言冈涧,尤其是6-18個(gè)月的...
    Ccc_zzz閱讀 283評(píng)論 0 2
  • 十月的傍晚 她佇立在白樺林 面對(duì)他的責(zé)問(wèn) 她閉口不言 雙眼透著哀憐 那把匕首透著寒光 慘白了她的容顏 猙獰了他的面...
    謊言才不會(huì)說(shuō)謊閱讀 153評(píng)論 0 1