GO語(yǔ)言的map類(lèi)型實(shí)例詳解
GO語(yǔ)言map的介紹
map的結(jié)構(gòu)就是key與value的形式,但它存儲(chǔ)是無(wú)序的,它是引用類(lèi)型,其實(shí)在某種程度上面說(shuō),map其實(shí)可以歸類(lèi)為數(shù)組,相當(dāng)于是在數(shù)組的基礎(chǔ)上做了一些擴(kuò)展,實(shí)現(xiàn)某些相應(yīng)的功能
GO語(yǔ)言map的定義格式
var map變量 map[key的類(lèi)型] value的類(lèi)型
map變量 = map[key的類(lèi)型] value的類(lèi)型{}例:
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類(lèi)似于數(shù)組,也可以使用`make`形式來(lái)賦值
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]的形式一樣,來(lái)操作map的值
做個(gè)小例子來(lái)加深一些影響:給定一個(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ì)是否存在
還記得在寫(xiě)變量賦值時(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í)不用返回值呢?
前面介紹過(guò),map是引用傳遞,在刪除時(shí),相當(dāng)于是直接刪除這片內(nèi)存的值
map的排序
由于map是無(wú)規(guī)則的存儲(chǔ),所以本身是不存在map排序的,但某些情況下,又需要排序,所以借助`for`來(lái)拿`key`戓`value`來(lái)進(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類(lèi)型,包括對(duì)map的創(chuàng)建,賦值,排序,刪除,等操作,更多關(guān)于GO語(yǔ)言的map相關(guān)知識(shí)請(qǐng)查看下面的相關(guān)鏈接
相關(guān)文章
一文帶你理解Golang中的Time結(jié)構(gòu)
根據(jù)golang的time包的文檔可以知道,golang的time結(jié)構(gòu)中存儲(chǔ)了兩種時(shí)鐘,一種是Wall?Clocks,一種是Monotonic?Clocks,下面我們就來(lái)簡(jiǎn)單了解一下這兩種結(jié)構(gòu)吧2023-09-09
GoLang使goroutine停止的五種方法實(shí)例
goroutine是Go并行設(shè)計(jì)的核心,下面這篇文章主要給大家介紹了關(guān)于GoLang使goroutine停止的五種方法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-07-07
Golang?channel關(guān)閉后是否可以讀取剩余的數(shù)據(jù)詳解
這篇文章主要介紹了Golang?channel關(guān)閉后是否可以讀取剩余的數(shù)據(jù),文章通過(guò)一個(gè)測(cè)試?yán)咏o大家詳細(xì)的介紹了是否可以讀取剩余的數(shù)據(jù),需要的朋友可以參考下2023-09-09
GO語(yǔ)言make和new關(guān)鍵字的區(qū)別
本篇文章來(lái)介紹一道非常常見(jiàn)的面試題,到底有多常見(jiàn)呢?可能很多面試的開(kāi)場(chǎng)白就是由此開(kāi)始的。那就是?new?和?make?這兩個(gè)內(nèi)置函數(shù)的區(qū)別,希望對(duì)大家有所幫助2023-04-04

