美文网首页
golang中的map

golang中的map

作者: 无拘无束的猪 | 来源:发表于2020-08-28 01:02 被阅读0次

1.map的结构

2.map顺序输出

2.1对key进行排序

func main() {
    m := make(map[string]string)
    m["b"] = "2"
    m["a"] = "1"
    m["c"] = "3"

    keys := make([]string, 0, len(m))
    for k, _ := range m {
        keys = append(keys, k)
    }

    sort.Strings(keys)
    //sort.Slice()

    for _, k := range keys {
        fmt.Printf("Key:%+v, Value:%+v\n", k, m[k])
    }
}
//通用方法
func sortedMap(m map[string]interface{}, f func(k string, v interface{})) {
    var keys []string
    for k := range m {
        keys = append(keys, k)
    }
    sort.Strings(keys)
    for _, k := range keys {
        f(k, m[k])
    }
}
//因为 Go 不支持泛型,所以该方法并不是很通用(当 key 不为 string 的时候),但终究算是一个解决办法。

2.2实现类型linkedhashmap

java采用多态hook实现顺序
第三方 API 返回的 JSON 中就是用 map 来保持顺序的

package main

import (
    "fmt"
    "github.com/virtuald/go-ordered-json"
)

func main() {
    jsonString := `{
    "b": "2",
    "a": "1",
    "c": "3"
}`

    oo := json.OrderedObject{}
    err := json.Unmarshal([]byte(jsonString), &oo)
    if err != nil {
        panic(err)
    }
    fmt.Printf("%+v", oo)
}
//[{Key:b Value:2} {Key:a Value:1} {Key:c Value:3}]
//json.OrderedObject 内部把 map 处理成了 slice,json.OrderedObject 只处理顶层的这个 map,如果嵌套有 map 的话,下层的 map 还是无序的。

2.3encoding/json 库

扮演着 struct 转换器的角色
用它对 map 进行 encode 的时候(就是 json.Marshal )

package main

import (
    "encoding/json"
    "fmt"
)

func main() {
    jsonString := `{
    "foo": {
        "b": "1",
        "a": "2",
        "c": "3"
    }
}`
    o := make(map[string]map[string]string)
    err := json.Unmarshal([]byte(jsonString), &o)
    if err != nil {
        panic(err)
    }

    fmt.Println("range:")
    for _, m := range o {
        for k, v := range m {
            fmt.Printf("%s, %s\n", k, v)
        }
    }

    bytes, err := json.Marshal(o)
    if err != nil {
        panic(err)
    }

    fmt.Println("")
    fmt.Println("json:")
    fmt.Printf("%s\n", bytes)
}

3.map线程安全

4.底层实现

参考

golang实现sortedhashmap和linkedhashmap
底层实现
底层实现2

相关文章

  • 我设计的golang面试题

    1 golang中的引用类型 ``` slice、map、channel、interface ``` 2、map如...

  • Go map底层实现

    golang map源码详解Golang map 如何进行删除操作?

  • golang语言map的并发和排序

    golang语言map的并发和排序 map的并发问题 golang缺省的map不是thread safe的,如果存...

  • golang中的map

    在golang中map是经常用到的数据结构。在这篇中我会从基础、算法、源码角度去分析map中的设计思想。 1 基础...

  • golang中的map

    1.map的结构 2.map顺序输出 2.1对key进行排序 2.2实现类型linkedhashmap java采...

  • Golang map

    Golang map map用来存储多个键值对,与java中的map功能相似。 直接声明 需要注意: key,va...

  • (九)golang sync map 源码分析

    golang中的map是不支持并发操作的,golang推荐用户直接用读写锁对map进行保护,也有第三方类库使用分段...

  • 剖析golang map的实现

    [TOC] 本文参考的是golang 1.10源码实现。 golang中map是一个kv对集合。底层使用hash ...

  • Go-Map

    go map golang中的map是一种(无序的)key-value形式的数据结构,类似python中的字典,默...

  • map golang

    原文链接:map-GOLANG

网友评论

      本文标题:golang中的map

      本文链接:https://www.haomeiwen.com/subject/hrrksktx.html