日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

GO語言的map類型實例詳解_Golang

作者:astarblog ? 更新時間: 2023-01-19 編程語言

GO語言map的介紹

map的結構就是keyvalue的形式,但它存儲是無序的,它是引用類型,其實在某種程度上面說,map其實可以歸類為數組,相當于是在數組的基礎上做了一些擴展,實現某些相應的功能

GO語言map的定義格式

var map變量 map[key的類型] value的類型
map變量 = map[key的類型] value的類型{}

例:

var map1 map[int]string
fmt.Println(map1)
map1 = map[int]string{1:"a",2:"b"}
fmt.Println(map1)

輸出為:

map[]
map[1:a 2:b]

map在初始化時,如果不賦值,默認值為`nil` 也就是空值

map類似于數組,也可以使用`make`形式來賦值

var map1 = make(map[int]string)
fmt.Println(map1)
map1[1] = "a"
fmt.Println(map1)

輸出:

map[]
map[1:a]

使用make進行聲明和初始化后,就可以像使用數組arr[i]的形式一樣,來操作map的值

做個小例子來加深一些影響:給定一個map的格式并賦值,讓map的鍵與值交換位置

package main
import "fmt"
func main(){
    var map1 = map[int]string{1: "a", 2: "b", 3: "c", 4: "d"}
    fmt.Println(map1)
    var map2 = make(map[string]int)
    for k,v := range map1{
        map2[v] =k
    }
    fmt.Println(map2)
}

?輸出為:

map[2:b 3:c 4:d 1:a]
map[c:3 d:4 a:1 b:2]

檢測map的鍵值對是否存在

還記得在寫變量賦值時的這種形式嗎?

var str = "str"
var str1,_ = str

就是上面的`_`,在GO語言中,會返回兩個狀態,一個是返回的值,另一個是值的狀態,如果值為真,后面的`_`是`true`,否則為`false`

package main
import "fmt"
func main(){
    var map2 = make(map[string]int)
    fmt.Println(map2)
    if _, err := map2["a"]; err {
        map2["e"] = 5
    }
    fmt.Println(map2)
}

輸出為:

map[b:2 e:5 c:3 d:4 a:1]

在上面的例子中,當`map2["a"]` 的值為真是,就給`map2`新加了一個值,反之,就可以判斷這個鍵是否存在

刪除map里的某個鍵值

直接 `delete(map1, key1)` 就可以

var map1 = map[int]string{1: "a", 2: "b", 3: "c", 4: "d"}
fmt.Println(map1)
delete(map1, 2)
fmt.Println(map1)

?輸出為:

map[1:a 2:b 3:c 4:d]
map[1:a 3:c 4:d]

為什么使用`delete`刪除map時不用返回值呢?

前面介紹過,map是引用傳遞,在刪除時,相當于是直接刪除這片內存的值

map的排序

由于map是無規則的存儲,所以本身是不存在map排序的,但某些情況下,又需要排序,所以借助`for`來拿`key`戓`value`來進行相對應的排序,然后重新賦值

package main
import (
    "fmt"
    "sort"
)

var (
    barVal = map[string]int{"alpha": 34, "bravo": 56, "charlie": 23, "delta": 87, "echo": 56, "foxtrot": 12, "golf": 34, "hotel": 16, "indio": 87,"juliet": 65, "kili": 43, "lima": 98}
)
func main() {
    for k, v := range barVal {
        fmt.Printf("Key: %v, Value: %v / ", k, v)
    }
     keys := make([]string, len(barVal))
    i := 0
    for k, _ := range barVal {
        keys[i] = k
    i++
    }
    sort.Strings(keys)
    fmt.Println()
    fmt.Println("sorted:")
    for _, k := range keys {
        fmt.Printf("Key: %v, Value: %v / ", k, barVal[k])
    }
}

可以自行跑下上面的那串代碼,更多關于map的相關知識,可以查閱GO的相關文檔

原文鏈接:https://www.jianshu.com/p/78dd3de6d0d9

欄目分類
最近更新