zoukankan      html  css  js  c++  java
  • go map数据结构

    map数据结构

    key-value的数据结构,又叫字典或关联数组

    • 声明:
    var map1 map[keytype]valuetype
    var a map[string]string
    var a map[string]int
    var a map[int]string
    var a map[string]map[string]string
    

    备注:声明是不会分配内存的,初始化需要make

    样例一:

    func testMap() {
        var a map[string]string
        a = make(map[string]string, 10)
        a["abc"] = "efg"
        a["abc"] = "efg"
        a["abc1"] = "efg"
        fmt.Println(a)
    }

    样例二:

    func testMap() {
        a := make(map[string]string, 10)
        a["abc"] = "efg"
        a["abc"] = "efg"
        a["abc1"] = "efg"
        fmt.Println(a)
    }

    样例三:

    func testMap() {
    	var a map[string]string = map[string]string{
    		"key": "value",
    	}
    	a["abc"] = "efg"
    	a["abc"] = "efg"
    	a["abc1"] = "efg"
    	fmt.Println(a)
    }
    

    • map相关操作
    var a map[string]string = map[string]string{"hello": "world"}
    a = make(map[string]string, 10)

    插入和更新:a[“hello”] = “world”

    查找:Val, ok := a[“hello”]

    遍历:

    for k, v := range a { 
        fmt.Println(k,v) 
    }

    删除:delete(a, “hello”)

    长度:len(a)

    func trans(a map[string]map[string]string) {
    	for k, v := range a {
    		fmt.Println(k)
    		for k1, v1 := range v {
    			fmt.Println("	", k1, v1)
    		}
    	}
    }
    
    func testMap4() {
    	a := make(map[string]map[string]string, 100)
    	a["key1"] = make(map[string]string)
    	a["key1"]["key2"] = "abc"
    	a["key1"]["key3"] = "abc"
    	a["key1"]["key4"] = "abc"
    	a["key1"]["key5"] = "abc"
    
    	a["key2"] = make(map[string]string)
    	a["key2"]["key2"] = "abc"
    	a["key2"]["key3"] = "abc"
    
    	trans(a)
    	delete(a, "key1")
    	fmt.Println()
    	trans(a)
    	fmt.Println(len(a))
    }
    
    • 多层map
    func testMap2() {
    	a := make(map[string]map[string]string, 100)
    	a["key1"] = make(map[string]string)
    	a["key1"]["key2"] = "abc"
    	a["key1"]["key3"] = "abc"
    	a["key1"]["key4"] = "abc"
    	a["key1"]["key5"] = "abc"
    	fmt.Println(a)
    }
    

    • slice of map
    func testMapSlice() {
       s := make([]map[string]int, 10)
       for i := 0; i < len(s); i++ {
          s[i] = make(map[string]int, 100)
       }
       s[0]["abc"] = 100
       s[0]["qwe"] = 100
       s[5]["abc"] = 100
       fmt.Println(s)
    }

    备注:上面第一次make是切片的长度,第二次make是map的容量

    • map排序

    a. 先获取所有key,把key进行排序

    b. 按照排序好的key,进行遍历

    func testMapSort() {
    	var a map[int]int
    	a = make(map[int]int, 5)
    
    	a[8] = 10
    	a[3] = 10
    	a[2] = 10
    	a[1] = 10
    	a[18] = 10
    
    	var keys []int
    	for k, _ := range a {
    		keys = append(keys, k)
    		//fmt.Println(k, v)
    	}
    
    	sort.Ints(keys)
    
    	for _, v := range keys {
    		fmt.Println(v, a[v])
    	}
    }
    

    • map反转

    初始化另外一个map,把key、value互换即可

    func test() {
    	var a map[string]int
    	var b map[int]string
    
    	a = make(map[string]int, 5)
    	b = make(map[int]string, 5)
    
    	a["abc"] = 101
    	a["efg"] = 10
    
    	fmt.Println(a)
    
    	for k, v := range a {
    		b[v] = k
    	}
    
    	fmt.Println(b)
    }
    

  • 相关阅读:
    Nginx文件下载服务器部署
    Git分支命名规范
    ROS通信介绍
    linux环境设置默认路由的优先级
    Python日志方案
    Python threading Local()函数用法:返回线程局部变量
    Python中websocket的使用示例
    MQTT的Python使用示例
    利用systemback打包个人ISO系统镜像
    Spring Security学习笔记三
  • 原文地址:https://www.cnblogs.com/shhnwangjian/p/7446995.html
Copyright © 2011-2022 走看看