008.golang map

map

  • 类似其它语言中的哈希表或者字典,以key-value形式存储数据
  • Key必须是支持==或!=比较运算的类型,不可以是函数、map或slice
  • Map查找比线性搜索快很多,但比使用索引访问数据的类型慢100倍
  • Map使用make()创建,支持 := 这种简写方式
  • make([keyType]valueType,cap),cap表示容量,可省略
    • 超出容量时会自动扩容,但尽量提供一个合理的初始值
    • 使用len()获取元素个数
  • 键值对不存在时自动添加,使用delete()删除某键值对
  • 使用 for range 对map和slice进行迭代操作

package main

import (
    "fmt"
)

func main() {
    //map的声明
    var m map[int]string
    m = make(map[int]string)

    var m1 map[int]string = make(map[int]string)
    m2 := make(map[int]string)

    fmt.Println(m)
    fmt.Println(m1)
    fmt.Println(m2)
}

package main

import (
    "fmt"
)

func main() {
    //map的初始化以及赋值
    m := make(map[int]string)
    a := m[1]
    fmt.Println(a)
    m[3] = "Three"
    b := m[3]
    fmt.Println(b)
}

package main

import (
    "fmt"
)

func main() {
    var m map[int]map[int]string
    m = make(map[int]map[int]string)
    m[1] = make(map[int]string)
    a,ok := m[1][1]
    fmt.Println(ok)
    if !ok {
        m[1][1] = "OK"
    }
    a,ok = m[1][1]
    fmt.Println(a,ok)

}

package main

import (
    "fmt"
)

func main() {
    sm := make([]map[int]string, 5)
    for _,v := range sm {
        //v只是一个拷贝,对它的操作不会影响其源值
        v = make(map[int]string, 1)
        v[1] = "OK"
        fmt.Println(v)
    }
    fmt.Println(sm)

    for i := range sm {
        //v只是一个拷贝,对它的操作不会影响其源值
        sm[i] = make(map[int]string, 1)
        sm[i][1] = "OK"
        fmt.Println(sm[i])
    }
    fmt.Println(sm)

}

package main

import (
    "fmt"
)

func main() {
    //map的无序性
    m := map[int]string{1: "a", 2: "b", 3: "c", 4: "d", 5: "e"}
    s := make([]int,len(m))
    i := 0
    for k,_ := range m {
        s[i] = k
        i++
    }
    //多次执行,每次打印的值都是不一样的
    fmt.Println(s)
}

package main

import (
    "fmt"
    "sort" //新增sort排序模块
)

func main() {
    //map的无序性
    m := map[int]string{1: "a",_ := range m {
        s[i] = k
        i++
    }
    //对map的key进行排序
    sort.Ints(s)
    fmt.Println(s)
    //曲折对map进行排序
    for k,_ := range s {
        fmt.Println(m[k])
    }

}

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...