大家好,我是东东吖,本人是一名前端工程师,期望借助go言语能打通前后端的任通二脉,成为一名全栈工程师!另外,需求进技术沟通群的同学,能够加我微信fangdongdong_25,需求进前端工程师沟通群的补白“前端”,需求进go后端沟通群的补白“go后端”

1.map界说

Go言语中供给的映射联系容器map,map是一种无序的基于key-value的数据结构,Go言语中的map是引用类型,有必要初始化才干运用。

Go言语中map的界说语法如下:

map[KeyType]ValueType

其间,

  • KeyType:表明键的类型。
  • ValueType:表明键对应的值的类型。

map类型的变量默许初始值为nil,需求运用make()函数来分配内存。语法为:

make(map[KeyType]ValueType, [cap])

其间cap表明map的容量,该参数虽然不是有必要的,可是咱们应该在初始化map的时分就为其指定一个合适的容量。

2.map基本运用

map中的数据都是成对呈现的,map的基本运用示例代码如下:

func main() {
    scoreMap := make(map[string]int, 8)
    scoreMap["张三"] = 90
    scoreMap["小明"] = 100
    fmt.Println(scoreMap)
    fmt.Println(scoreMap["小明"])
    fmt.Printf("type of a:%T\n", scoreMap)
}
 //输出:
  map[小明:100 张三:90]
    100
    type of a:map[string]int

map也支持在声明的时分填充元素

func main() {
    userInfo := map[string]string{
        "username": "pprof.cn",
        "password": "123456",
    }
    fmt.Println(userInfo) //
}

3.判别某个键是否存在

Go言语中有个判别map中键是否存在的特殊写法,格局如下:

 value, ok := map[key]
func main() {
    scoreMap := make(map[string]int)
    scoreMap["张三"] = 90
    scoreMap["小明"] = 100
    // 如果key存在ok为true,v为对应的值;不存在ok为false,v为值类型的零值
    v, ok := scoreMap["张三"]
    if ok {
        fmt.Println(v)
    } else {
        fmt.Println("查无此人")
    }
}

4.map的遍历

Go言语中运用for range遍历map。

func main() {
    scoreMap := make(map[string]int)
    scoreMap["张三"] = 90
    scoreMap["小明"] = 100
    scoreMap["王五"] = 60
    for k, v := range scoreMap {
        fmt.Println(k, v)
    }
}

但咱们只想遍历key的时分,能够按下面的写法:

func main() {
    scoreMap := make(map[string]int)
    scoreMap["张三"] = 90
    scoreMap["小明"] = 100
    scoreMap["王五"] = 60
    for k := range scoreMap {
        fmt.Println(k)
    }
}

遍历map时的元素次序与增加键值对的次序无关

5.运用delete()函数删去键值对

运用delete()内建函数从map中删去一组键值对,delete()函数的格局如下:

    delete(map, key)

其间,

    map:表明要删去键值对的map
    key:表明要删去的键值对的键
func main(){
    scoreMap := make(map[string]int)
    scoreMap["张三"] = 90
    scoreMap["小明"] = 100
    scoreMap["王五"] = 60
    delete(scoreMap, "小明")//将小明:100从map中删去
    for k,v := range scoreMap{
        fmt.Println(k, v)
    }
}

6.依照指定次序遍历map

 func main() {
    rand.Seed(time.Now().UnixNano()) //初始化随机数种子
    var scoreMap = make(map[string]int, 200)
    for i := 0; i < 100; i++ {
        key := fmt.Sprintf("stu%02d", i) //生成stu开头的字符串
        value := rand.Intn(100)          //生成0~99的随机整数
        scoreMap[key] = value
    }
    //取出map中的一切key存入切片keys
    var keys = make([]string, 0, 200)
    for key := range scoreMap {
        keys = append(keys, key)
    }
    //对切片进行排序
    sort.Strings(keys)
    //依照排序后的key遍历map
    for _, key := range keys {
        fmt.Println(key, scoreMap[key])
    }
}

7.元素为map类型的切片

func main() {
    var mapSlice = make([]map[string]string, 3)
    for index, value := range mapSlice {
        fmt.Printf("index:%d value:%v\n", index, value)
    }
    fmt.Println("after init")
    // 对切片中的map元素进行初始化
    mapSlice[0] = make(map[string]string, 10)
    mapSlice[0]["name"] = "王五"
    mapSlice[0]["password"] = "123456"
    mapSlice[0]["address"] = "红旗大街"
    for index, value := range mapSlice {
        fmt.Printf("index:%d value:%v\n", index, value)
    }
}

8.值为切片类型的map

func main() {
    var sliceMap = make(map[string][]string, 3)
    fmt.Println(sliceMap)
    fmt.Println("after init")
    key := "中国"
    value, ok := sliceMap[key]
    if !ok {
        value = make([]string, 0, 2)
    }
    value = append(value, "北京", "上海")
    sliceMap[key] = value
    fmt.Println(sliceMap)
}

结束:

再次提示,需求进技术沟通群的同学,能够加我微信fangdongdong_25,需求进前端工程师沟通群的补白“前端”,需求进go后端沟通群的补白“go后端”