map的介紹
map的結(jié)構(gòu)就是key
與value
的形式让腹,但它存儲(chǔ)是無(wú)序
的赡若,它是引用
類型,其實(shí)在某種程度上面說表鳍,map其實(shí)可以歸類為數(shù)組馅而,相當(dāng)于是在數(shù)組的基礎(chǔ)上做了一些擴(kuò)展,實(shí)現(xiàn)某些相應(yīng)的功能
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在初始化時(shí)譬圣,如果不賦值瓮恭,默認(rèn)值為`nil` 也就是空值
map類似于數(shù)組,也可以使用`make`形式來賦值
```
var map1 = make(map[int]string)
fmt.Println(map1)
map1[1] = "a"
fmt.Println(map1)
```
輸出:
```
map[]
map[1:a]
```
使用`make`進(jìn)行聲明和初始化后厘熟,就可以像使用數(shù)組`arr[i]`的形式一樣屯蹦,來操作map的值
做個(gè)小例子來加深一些影響:給定一個(gè)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]
```
# 檢測(cè)map的鍵值對(duì)是否存在
還記得在寫變量賦值時(shí)的這種形式嗎?
```
var str = "str"
var str1,_ = str
```
就是上面的`_`,在GO語(yǔ)言中登澜,會(huì)返回兩個(gè)狀態(tài)阔挠,一個(gè)是返回的值,另一個(gè)是值的狀態(tài)脑蠕,如果值為真购撼,后面的`_`是`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]
```
在上面的例子中,當(dāng)`map2["a"]` 的值為真是谴仙,就給`map2`新加了一個(gè)值迂求,反之,就可以判斷這個(gè)鍵是否存在
# 刪除map里的某個(gè)鍵值
直接 `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時(shí)不用返回值呢晃跺?
> 前面介紹過,map是引用傳遞揩局,在刪除時(shí),相當(dāng)于是直接刪除這片內(nèi)存的值
# map的排序
尤于map是無(wú)規(guī)則的存儲(chǔ)掀虎,所以本身是不存在map排序的凌盯,但某些情況下,又需要排序烹玉,所以借助`for`來拿`key`戓`value`來進(jìn)行相對(duì)應(yīng)的排序驰怎,然后重新賦值
```
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])
}
}
```
可以自行跑下上面的那串代碼,更多關(guān)于map的相關(guān)知識(shí)春霍,可以查閱GO的相關(guān)文檔
> 本篇重點(diǎn)介紹了GO的map類型,下一篇將介紹GO的function聲明調(diào)用與閉包
如果覺得文章能夠?qū)δ兴鶐椭睹迹梢躁P(guān)注我址儒,你的支持會(huì)鼓勵(lì)我不斷分享更多更好的優(yōu)質(zhì)文章。