Go有序map:orderedmap

news2025/1/23 11:53:14

有序映射

与传统的无序映射(Map)不同,orderedmap包中的有序映射(OrderedMap)可以记录键值对的插入顺序。orderedmap提供了一些有用的API,用来存储、删除、查询和遍历键值对。

获取OrderedMap

你可以通过OrderedMap在github上的地址来访问OrderedMap。或者通过下面的方式手动获取:

git clone https://github.com/liushuochen/orderedmap.git

API

创建一个有序映射实例

使用orderedmap.New函数来创建一个有序映射实例:

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)

func main() {
    o := orderedmap.New()
    fmt.Printf("%T", o)
    // output: *orderedmap.OrderedMap
}

存储数据

使用OrderedMap实例的Store方法来存储一个数据。OrderedMap依据数据的插入顺序来存放数据。Store方法接收两个interface{}类型的参数key和value,分别表示有序映射的键和值。

下面是Store方法的签名:

func (om *OrderedMap) Store(key, value interface{})

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)

func main() {
    o := orderedmap.New()
    o.Store("name", "Pizza")
    o.Store("price", 50)
    o.Store("size", "10#")
    fmt.Println(o)
    // output: {name: Piza price: 50 size: 10#}
}

读取数据

使用OrderedMap实例的Load方法来获取某个key对应的value。如果指定的key在映射中不存在,Load方法返回一个nil和一个标记false。下面是Load方法的签名:

func (om *OrderedMap) Load(key interface{}) (interface{}, bool)

对于存在的key,Load方法返回映射中key对应的value和一个标记为true的bool值:

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)

func main() {
    o := orderedmap.New()
    o.Store("name", "Pizza")
    o.Store("price", 50)
    o.Store("size", "10#")

    size, ok := o.Load("size")
    fmt.Println(size, ok)
    // output: 10# true

    color, ok := o.Load("color")
    fmt.Println(color, ok)
    // output: <nil> false
}

删除数据

使用OrderedMap实例的Delete方法来删除指定的键值对。如果指定要删除的key在Map中不存在,Delete方法不会做任何事。Delete方法会线性的查找要删除的Key,因此时间复杂度是

func (om *OrderedMap) Delete(key interface{})

下面是代码示例:

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)


func main() {
    o := orderedmap.New()
    o.Store("name", "Pizza")
    o.Store("price", 50)
    o.Store("size", "10#")
    fmt.Println("Before using delete method, the content of orderedmap is: ", o)
    // Before using delete method, the content of orderedmap is:  {name: Pizza price: 50 size: 10#}

    o.Delete("size")
    fmt.Println("After using delete method, the content of orderedmap is: ", o)
    // After using delete method, the content of orderedmap is:  {name: Pizza price: 50}
}

遍历

Range方法可以遍历OrderedMap的每一个键值对(但不能遍历嵌套的结构)。Range方法的参数是一个函数f:

f func(key, value interface{}) bool

如果函数f的返回结果为false,那么遍历终止。

Range方法的签名如下:

func (om *OrderedMap) Range(f func(key, value interface{}) bool)

下面的例子演示了遍历OrderedMap中的每一个键值对,并将Key和Value打印:

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)

func main() {
    o := orderedmap.New()
    o.Store("A", "a")
    o.Store("B", "b")

    f := func(key, value interface{}) bool {
        fmt.Printf("key: %v, value: %v\n", key, value)
        return true
    }

    o.Range(f)
    // outputs:
    // key: A, value: a
    // key: B, value: b
}

获取长度

使用Length方法来获取OrderedMap实例的长度,即键值对数量(不包含嵌套的键值对)。

func (om *OrderedMap) Length() int

下面的例子是在给OrderedMap实例添加了两个元素后,然后计算其长度:

package main

import (
    "fmt"
    "github.com/liushuochen/orderedmap"
)

func main() {
    o := orderedmap.New()
    o.Store("A", "a")
    o.Store("B", "b")

    fmt.Println(o.Length())
    // output: 2
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/493485.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

地面分割--Fast Segmentation of 3D Point Clouds for Ground Vehicles论文阅读与源码分析

文章目录 1写在前面的话2点云投影分块3地面点云分割4核心代码阅读投影分块直线拟合代码分割地面点云 5实验效果参考 1写在前面的话 这篇文章属于地面分割领域非常经典的一篇论文&#xff0c;论文具有速度快&#xff0c;在一定程度能适应有坡度的地形&#xff0c;文章主要分为两…

学习使用ansible自动化运维工具

目录 一、虚拟机环境 二、yum方式部署 三、ansible使用 &#xff08;一&#xff09;将ansible服务器上文件分发给各节点 1. 创建一个要复制的文件&#xff0c;并复制到Ansible管理主机上 2.编辑Ansible的playbook文件&#xff0c;将copy模块添加到任务列表中 3. 运行play…

【c++迭代器模拟实现】

目录&#xff1a; 前言一、STL初始二、六大组件之迭代器迭代器初始迭代器的模拟实现&#xff08;1&#xff09;victor正向迭代器反向迭代器1反向迭代器2反向迭代器3 &#xff08;2&#xff09;list正向迭代器反向迭代器 总结 前言 打怪升级&#xff1a;第52天 一、STL初始 什…

和chatgpt一样的大模型LLaMA可以运行在pc上?

未来已来,大模型依据压缩模型的方式,可以在普通的PC上运行. LLaMA Facebook的LLaMA 模型和Georgi Gerganov 的llama.cpp的结合。 LLaMA&#xff0c;这是一组包含 7B 到 65B 参数的基础语言模型。我们在数万亿个令牌上训练我们的模型&#xff0c;并表明可以仅使用公开可用的数…

【Android入门到项目实战-- 9.1】—— 传感器的使用教程

目录 传感器的定义 三大类型传感器 1、运动传感器 2、环境传感器 3、位置传感器 传感器开发框架 1、SensorManager 2、Sensor 3、SensorEvent 4、SensorEventListener 一、使用传感器开发步骤 1、获取传感器信息 1)、获取传感器管理器 2)、获取设备的传感器对象列…

Java红黑树

概述 红黑树是一种自平衡的二叉查找树&#xff0c;是计算机科学中用到的一种数据结构。1972年出现的&#xff0c;当时被称之为平衡二叉B树。在1978年被修改为红黑树。红黑树是一种特殊的二叉查找树&#xff0c;红黑树上的每一个节点都有存储位表示节点的颜色。每一个节点可以是…

Java枚举:为什么它是单例模式的最佳选择?

前言 单例模式&#xff0c;是工作中比较常见的一种设计模式&#xff0c;通常有两种实现方式&#xff0c;懒汉式和饿汉式。但是这两种实现方式存在一些问题。懒汉式需要在多线程环境下使用同步锁机制来保证只有一个实例被创建&#xff0c;这会影响程序的性能。而饿汉式在类加载时…

《发展心理学——儿童与青少年》读书笔记

这是我读的第一本关于育儿教育类的书&#xff0c;该书的作者是David R. Shaffer&#xff0c;由北京师范大学博士生导师邹泓审校&#xff0c;由其底下的博士生们翻译。我看的是中文第九版。下面是我在阅读此书时做的关键摘录和部分感想&#xff1a; 第1章 导论:发展心理学及其研…

Java基础(二十一):集合源码

Java基础系列文章 Java基础(一)&#xff1a;语言概述 Java基础(二)&#xff1a;原码、反码、补码及进制之间的运算 Java基础(三)&#xff1a;数据类型与进制 Java基础(四)&#xff1a;逻辑运算符和位运算符 Java基础(五)&#xff1a;流程控制语句 Java基础(六)&#xff1…

耗时2.5h含泪打造windows10家庭版docker安装

文章目录 一、事出有因二、安装流程Problem1Problem2Problem3 三、胜利的曙光 一、事出有因 由于最近需要跑通github上的一个代码&#xff0c;那个github上的代码需要通过docker部署到本地&#xff0c;但是我的电脑上并没有docker,真的是含泪历时2.5h才把docker在我的windows电…

【Python成长之路】基于Flask-admin库,结合html+vue,实现前后端数据传递

一、前言 前面已经做了Flask-admin库的基本介绍和几个库常用功能如何使用&#xff0c;若不了解请移步到以下博客&#xff1a; 1、?《【Python成长之路】基于Flask-admin库&#xff0c;编写个人工作平台代码详述》 2、?《【Python成长之路】基于Flask-admin库&#xff0c;编…

DP练习题

1.减操作(ACWING) 若有 a b c d e f g 几个数&#xff0c; 先对位置d操作 变成 a b c d - e f g 再对c操作 变成 a b c - (d-e) f g 仔细分析后得出结论&#xff1a;对于第一个数如a, 它一定为正数&#xff0c;第二个数b,一定为负数&#…

Java并发(四)----线程运行原理

1、线程运行原理 1.1 栈与栈帧   Java Virtual Machine Stacks &#xff08;Java 虚拟机栈 JVM&#xff09; 我们都知道 JVM 中由堆、栈、方法区所组成&#xff0c;其中栈内存是给谁用的呢&#xff1f;其实就是线程&#xff0c;每个线程启动后&#xff0c;虚拟机就会为其分…

java 解密springboot的WEB端口是谁启动的之内嵌tomcat

找到项目的 pom.xml 看到下面的spring-boot-starter-web 我们按住 Ctrl 点击进去 里面就有一个 tomcat 简单说 我们的程序能启动起tomcat端口 就是靠的这个东西 简单说 就是在程序中嵌了一个tomcat服务器 这里 可能就有小伙伴蒙了 不是把程序放在服务器上运行吗&#xff1f…

Linux Driver 和Device匹配过程分析(2)

Linux Driver 和Device匹配过程分析&#xff08;2&#xff09; 1 device注册流程2&#xff0c;driver注册匹配过程&#xff1a;2.1 pci_register_driver2.1.1 nvme_init2.1.2 pci_register_driver2.1.3 __pci_register_driver2.1.4 driver_register2.1.5 bus_add_driver2.1.6 d…

读书笔记——《2001太空漫游》

阿瑟克拉克神作&#xff0c;任何一个科幻迷都绕不开的一部作品。很早就听说过其大名&#xff0c;因为之前看过电影版的&#xff0c;总感觉少了点新鲜感&#xff0c;这本书就一直在书架上没有拿出来看。但是看过这本书后&#xff0c;我可以很负责任的说&#xff0c;全书都充满新…

【递推专题】常见的递推“模型”总结

目录 1.斐波那契数列分析&#xff1a;代码&#xff1a; 2.平面分割问题分析&#xff1a; 3.汉诺塔问题分析&#xff1a; 4.卡特兰数分析&#xff1a; 5.第二类斯特林数总结&#xff1a; 1.斐波那契数列 分析&#xff1a; 斐波那契数列又称兔子数列&#xff0c;其原理来源于兔子…

dangerousRemoteUrlIpcAccess

问题描述&#xff1a; 在使用Tauri窗口加载外部链接时&#xff0c;需要也能继续使用Tauri API与Rust交互。按照官方发布通告中的代码添加配置&#xff1a; "security": {"dangerousRemoteUrlIpcAccess": [ { "windows": ["main", &qu…

在Linux中进行Jenkins部署(maven-3.9.1+jdk8)

Jenkins部署在公网IP为x.x.x.x的服务器上 maven-3.9.1要安装在jdk8环境中 环境准备 第一步&#xff0c;下载server-jre-8u202-linux-x64.tar.gz安装包。 登录地址&#xff1a;https://www.oracle.com/java/technologies/javase/javase8-archive-downloads.html下载server-j…

Maven命令和配置详解

Maven命令和配置详解 1. pom基本结构2. build基本结构3. Maven命令详解3.1 打包命令3.2 常用命令3.3 批量修改版本-父子pom4. Maven配置详解4.1 settings.xml4.2 项目内的maven工程结构Maven POM构建生命周期工程实践1. pom基本结构 <?xml versi