GO語言的map類型實(shí)例詳解
GO語言map的介紹
map的結(jié)構(gòu)就是key
與value
的形式,但它存儲(chǔ)是無序
的,它是引用
類型,其實(shí)在某種程度上面說,map其實(shí)可以歸類為數(shù)組,相當(dāng)于是在數(shù)組的基礎(chǔ)上做了一些擴(kuò)展,實(shí)現(xiàn)某些相應(yīng)的功能
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在初始化時(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語言中,會(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是無規(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類型,包括對(duì)map的創(chuàng)建,賦值,排序,刪除,等操作,更多關(guān)于GO語言的map相關(guān)知識(shí)請(qǐng)查看下面的相關(guān)鏈接
相關(guān)文章
golang 實(shí)現(xiàn)tcp轉(zhuǎn)發(fā)代理的方法
今天小編就為大家分享一篇golang 實(shí)現(xiàn)tcp轉(zhuǎn)發(fā)代理的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08通過Go channel批量讀取數(shù)據(jù)的示例詳解
批量處理的主要邏輯是:從 channel 中接收數(shù)據(jù),積累到一定數(shù)量或者達(dá)到時(shí)間限制后,將數(shù)據(jù)批量處理(例如發(fā)送到 Kafka 或者寫入網(wǎng)絡(luò)),下面我將展示一個(gè)從 Go channel 中批量讀取數(shù)據(jù),并批量發(fā)送到 Kafka 和批量寫入網(wǎng)絡(luò)數(shù)據(jù)的示例,需要的朋友可以參考下2024-10-10Golang利用位運(yùn)算實(shí)現(xiàn)為程序加速
這篇文章主要為大家詳細(xì)介紹了如何在Golang中利用位運(yùn)算實(shí)現(xiàn)為程序加速功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2022-08-08Golang哈希算法實(shí)現(xiàn)配置文件的監(jiān)控功能詳解
這篇文章主要介紹了Golang哈希算法實(shí)現(xiàn)配置文件的監(jiān)控功能,哈希和加密類似,唯一區(qū)別是哈希是單項(xiàng)的,即哈希后的數(shù)據(jù)無法解密,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2023-03-03使用Go語言創(chuàng)建WebSocket服務(wù)的實(shí)現(xiàn)示例
這篇文章主要介紹了使用Go語言創(chuàng)建WebSocket服務(wù)的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-03-03淺談?dòng)肎o構(gòu)建不可變的數(shù)據(jù)結(jié)構(gòu)的方法
這篇文章主要介紹了用Go構(gòu)建不可變的數(shù)據(jù)結(jié)構(gòu)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09