返回顶部
首页 > 资讯 > 后端开发 > GO >如何利用Go语言实现LRU Cache
  • 874
分享到

如何利用Go语言实现LRU Cache

2024-04-02 19:04:59 874人浏览 独家记忆
摘要

目录1 基本概念2 代码实现3 测试使用1 基本概念 LRU是一个老生常谈的问题,即最近最少使用,LRU是Least Recently Used的缩写,是一种操作系统中常用的页面置换

1 基本概念

LRU是一个老生常谈的问题,即最近最少使用,LRU是Least Recently Used的缩写,是一种操作系统中常用的页面置换算法,选择最近最久未使用的页面予以淘汰。该算法赋予每个页面一个访问字段,用来记录一个页面自上次被访问以来所经历的时间 t,当须淘汰一个页面时,选择现有页面中其 t 值最大的,即最近最少使用的页面予以淘汰。

实现LRU基本的数据结构Map+LinkedList

一般规则:

  • 添加数据时,将新增数据节点放在头指针,尾结点部分大于最大长度时删除。
  • 删除数据时,先按照Map的规则进行查找,再根据链表规则进行删除。
  • 查找数据时,按照Map进行查找,没有则返回空,有则返回该数据的值并移动到头节点。

2 代码实现

package main
import "fmt"

var head *node
var end *Node

type Node struct {
   Key   string
   Value string
   pre   *Node
   next  *Node
}

func (n *Node) Init(key string, value string) {
   n.Key = key
   n.Value = value
}

type LRUCache struct {
   Capacity int              //页面初始化大小
   Size     int              //页面实际大小
   Map      map[string]*Node //具体的cache
}

func GetLRUCache(capacity int) *LRUCache {
   lruCache := LRUCache{Capacity: capacity}
   lruCache.Map = make(map[string]*Node, capacity)
   return &lruCache
}

func (l *LRUCache) get(key string) string {
   if v, ok := l.Map[key]; ok {
      l.refreshNode(v)
      return v.Value
   } else {
      return "null"
   }
}

func (l *LRUCache) put(key, value string) {
   if v, ok := l.Map[key]; !ok {
      if len(l.Map) >= l.Capacity {
         oldKey := l.removeNode(head)
         delete(l.Map, oldKey)
      }
      node := Node{Key: key, Value: value}
      l.addNode(&node)
      l.Map[key] = &node
   } else {
      v.Value = value
      l.refreshNode(v)
   }
}

func (l *LRUCache) refreshNode(node *Node) {
   if node == end {
      return
   }
   l.removeNode(node)
   l.addNode(node)
}

func (l *LRUCache) removeNode(node *Node) string {
   if node == end {
      end = end.pre
   } else if node == head {
      head = head.next
   } else {
      node.pre.next = node.next
      node.next.pre = node.pre
   }
   return node.Key
}

func (l *LRUCache) addNode(node *Node) {
   if end != nil {
      end.next = node
      node.pre = end
      node.next = nil
   }
   end = node
   if head == nil {
      head = node
   }
}

3 测试使用

func main() {
   lruCache := GetLRUCache(3)
   lruCache.put("001", "1")
   lruCache.put("002", "2")
   lruCache.put("003", "3")
   lruCache.put("004", "4")
   lruCache.put("005", "5")
   lruCache.get("002")
   fmt.Println(lruCache.get("001"))
   fmt.Println(lruCache.get("002"))
   fmt.Print(lruCache.Map)
}

到此这篇关于如何利用Go语言实现LRU Cache的文章就介绍到这了,更多相关Go实现LRU Cache内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: 如何利用Go语言实现LRU Cache

本文链接: https://lsjlt.com/news/141468.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何利用Go语言实现LRU Cache
    目录1 基本概念2 代码实现3 测试使用1 基本概念 LRU是一个老生常谈的问题,即最近最少使用,LRU是Least Recently Used的缩写,是一种操作系统中常用的页面置换...
    99+
    2024-04-02
  • 怎么用Go语言实现LRU Cache
    小编给大家分享一下怎么用Go语言实现LRU Cache,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1 基本概念LRU是一个老生常谈的问题,即最近最少使用,LRU是Least Recently Used的缩写,是...
    99+
    2023-06-29
  • Go语言如何实现LRU算法的核心思想和实现过程
    这篇文章主要介绍了Go语言如何实现LRU算法的核心思想和实现过程,具有一定借鉴价值,需要的朋友可以参考下。下面就和我一起来看看吧。GO实现Redis的LRU例子常见的三种缓存淘汰算法有三种:FIFO,LRU和LFU实现LRU缓存淘汰算法1....
    99+
    2023-07-06
  • 如何利用Redis和Go语言实现缓存功能
    如何利用Redis和Go语言实现缓存功能缓存是一种常见的性能优化技术,它通过将数据存储在高速读取的介质中,例如内存中,来提高数据访问速度。Redis是一种高性能的键值存储数据库,Go语言是一种轻量级并发编程语言,两者的结合可以实现高效的缓存...
    99+
    2023-10-22
    Go语言 redis 缓存功能
  • 如何用 Go 语言实现 SCP
    随着数据传输的不断增长,传输大量数据时如何确保数据安全和传输效率变得越来越重要。SCP (Secure Copy Protocol)是一种安全传输文件的协议,与SSH (Secure Shell)一起使用。本文将介绍如何用 Go 语言实现 ...
    99+
    2023-05-14
  • Go语言实现LRU算法的核心思想和实现过程
    目录GO实现Redis的LRU例子1.FIFO/LFU/LRU算法简介2.LRU算法实现2.1核心数据结构2.2查找功能2.3删除2.4新增或修改GO实现Redis的LRU例子 常见...
    99+
    2023-05-20
    Go LRU算法 GoLang LRU算法
  • 如何利用go语言实现智能合约的功能
    在Go语言中实现智能合约的功能可以使用Solidity库来编写智能合约代码,并使用Go语言编写合约的部署和调用代码。以下是一个简单的...
    99+
    2023-10-12
    Go语言
  • 如何利用Go语言和容器实现高效的自然语言处理?
    自然语言处理(Natural Language Processing,简称NLP)一直是人工智能领域的研究热点,随着人们对语言处理技术的需求增加,如何实现高效的自然语言处理成为了人工智能领域的重要问题。本文将介绍如何利用Go语言和容器实现高...
    99+
    2023-10-06
    自然语言处理 容器 实时
  • Go 语言中如何利用多核 CPU 实现并行计算
    本篇文章给大家分享的是有关Go 语言中如何利用多核 CPU 实现并行计算,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。开始之前,我们先澄清两个概念,「多核」指的是有效利用 CP...
    99+
    2023-06-20
  • 如何利用Redis和Go语言实现分布式锁功能
    如何利用Redis和Go语言实现分布式锁功能引言:在分布式系统中,为了保证数据的一致性和并发安全,经常需要使用分布式锁来实现资源的互斥访问。本文将介绍如何利用Redis和Go语言实现分布式锁功能,并提供具体的代码示例。一、什么是分布式锁分布...
    99+
    2023-10-22
    Go语言 redis 分布式锁
  • 如何利用go语言实现Git重命名远程分支  
    本文小编为大家详细介绍“如何利用go语言实现Git重命名远程分支  ”,内容详细,步骤清晰,细节处理妥当,希望这篇“如何利用go语言实现Git重命名远程分支  ”文章能帮助大家解决疑惑,下面跟着小编的...
    99+
    2023-07-02
  • Go语言如何实现多态 
    这篇“Go语言如何实现多态 ”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Go语言如何实现多态 ”文章吧...
    99+
    2023-06-30
  • Go语言中锁如何实现
    今天小编给大家分享一下Go语言中锁如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Lock// Lock&n...
    99+
    2023-07-05
  • 如何利用go语言实现人工智能算法的功能
    要利用Go语言实现人工智能算法的功能,可以按照以下步骤进行:1. 确定人工智能算法:首先要确定要实现的人工智能算法,例如机器学习算法...
    99+
    2023-10-12
    Go语言
  • 如何在Go语言中利用for循环实现翻转操作
    标题:Go语言中利用for循环实现翻转操作的方法 在Go语言中,通过使用for循环可以很方便地对数组、切片等数据结构进行翻转操作。在本文中,我们将介绍如何利用for循环来实现数组和切片...
    99+
    2024-04-02
  • 如何利用Go语言统计字符出现频率
    标题:利用Go语言统计字符出现频率的方法和示例 在日常开发中,经常会遇到需要统计文本中各个字符出现频率的需求。使用Go语言进行字符出现频率统计是一种简单而高效的方式。本文将介绍如何利用...
    99+
    2024-03-13
    go语言 统计 频率
  • 利用Go语言可以实现哪些功能?
    go 语言的优势:并发性: goroutine 提供轻量级并发,提高多核 cpu 性能。网络编程: net/http 库 упрощает 构建 web 服务器和客户端。数据结构: 内置...
    99+
    2024-04-03
    编程语言 go语言 docker 网络编程
  • go语言如何实现数组的调用
    Go语言中可以使用索引来调用数组中的元素。索引从0开始,依次递增。以下是一个示例代码:```gopackage mainimport...
    99+
    2023-10-12
    Go语言
  • 分布式环境下,如何利用Go语言实现数组同步?
    随着互联网技术的飞速发展,分布式系统已经成为了一种必然的趋势。在分布式系统中,数据同步是一个非常重要的问题。在本文中,我们将介绍如何利用Go语言实现数组同步。 一、分布式数组同步的挑战 在分布式系统中,如果多个节点同时访问同一个数组,就会...
    99+
    2023-10-09
    数组 分布式 同步
  • 如何利用Redis和Go语言实现分布式计数器功能
    如何利用Redis和Go语言实现分布式计数器功能介绍:在分布式系统中,计数器是一种常见的功能需求。分布式计数器可以用于统计网站的访问量、消息队列的消费次数等场景下。Redis是一种高性能的内存数据库,而Go语言是一种轻量级的编程语言,结合这...
    99+
    2023-10-22
    Go语言 redis 分布式计数器
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作