Go?編程復(fù)雜數(shù)據(jù)類型?Map
一、Map 的定義
Go 中的 Map 是一組無需的 K-V 類型的數(shù)據(jù),與 Python 中的字典 Dict 和 Java 中的 HashMap 結(jié)構(gòu)類似。未被初始化的 Map 為 nil。
// Map 的結(jié)構(gòu) map[string]string
Map 的定義
func main() { // 使用 Map 結(jié)構(gòu) 函數(shù)定義 Map info := map[string]string{ "name": "Stark", "address": "NewYork", } fmt.Printf("%T, %v\n", info, info) // 使用 make 函數(shù)定義 Map polit := make(map[string]string) polit["nickname"] = "Maverick" polit["aircraft"] = "F18" fmt.Printf("%T, %v\n", polit, polit) // 定義空 Map maverick := map[string]string{} fmt.Printf("%T, %v", maverick, maverick) }
執(zhí)行上述代碼,輸出結(jié)果如下:
map[string]string, map[address:NewYork name:Stark]
map[string]string, map[aircraft:F18 nickname:Maverick]
map[string]string, map[]
Map 中的 Key
Map 中的 Key 必須是唯一的,且 Key 必須支持 ==
和 !=
比較操作符。Map 中 Key 可以是 int、rune、指針和結(jié)構(gòu)體等類型(支持 ==
和 !=
)
切片不支持比較(切片只能和 nil 比較),不能作為 Map 的 Key,數(shù)組支持比較操作,可以作為 Key。
func main() { structKey01 := structKey{name: "structKey01"} fmt.Printf("%T", structKey01) info := map[structKey]string{ structKey01: "Stark", } fmt.Printf("%T, %v\n", info, info) info1 := map[interfaceKey]string{ interfaceKey: "Stark", } fmt.Printf("%T, %v\n", info1, info1) } type structKey struct { name string } type interfaceKey interface { }
接口和結(jié)構(gòu)體可作為 Key,前提是所包含的屬性必須都是可以進(jìn)行 ==
或者 !=
比較的,如果包含一個(gè)屬性不可以進(jìn)行 ==
或者 !=
比較,便不能作為 Key。
二、Map 的操作
- 增加或者修改鍵值對(duì)
- 查詢,如果查詢的鍵不存在返回 空字符串
func main() { // 使用 Map 結(jié)構(gòu) 函數(shù)定義 Map info := map[string]string{ "name": "Stark", "address": "NewYork", } fmt.Printf("%p, %T, %v\n", info, info, info) // 增加 KV info["nickname"] = "IRONMAN" // 修改 info["name"] = "Tony Stark" fmt.Printf("%p, %T, %v\n", info, info, info) // 查詢,Key 存在 fmt.Println("名字屬性值是:", info["name"]) // 查詢,Key 不存在 fmt.Println("技能屬性值是:", info["weapon"]) // 添加一個(gè)空值的 KV info["balance"] = "" fmt.Println("余額屬性值是:", info["balance"]) }
執(zhí)行上述代碼,輸出結(jié)果如下:
0xc00010e180, map[string]string, map[address:NewYork name:Stark]
0xc00010e180, map[string]string, map[address:NewYork name:Tony Stark nickname:IRONMAN]
名字屬性值是: Tony Stark
技能屬性值是:
余額屬性值是:
根據(jù)上述代碼,查詢時(shí)如果 Key 不存在返回空字符串,如果 Key 的值是空字符串,那么查詢時(shí)返回的也是空字符串,顯然通過返回字符串是否為空來判斷 Key 是否存在是不準(zhǔn)確的。
應(yīng)該如何判斷 Key 是否存在?
Map 通過 [Key]
進(jìn)行取值時(shí)會(huì)有兩個(gè)返回值,第一個(gè)值是 Key 對(duì)應(yīng)的 Value,第二個(gè)值是布爾值,如果為 true 表示 Key 存在,否則表示 Key 不存在。
func main() { // 其余代碼保持不變 weaponVal, ok1 := info["weapon"] fmt.Printf("weapon 屬性值是:%v, 是否存在:%v\n", weaponVal, ok1) balanceVal, ok2 := info["balance"] fmt.Printf("balance 屬性值是:%v, 是否存在:%v\n", balanceVal, ok2) }
執(zhí)行上述代碼,輸出結(jié)果如下:
weapon 屬性值是:, 是否存在:false
balance 屬性值是:, 是否存在:true
刪除 Key 需要使用到內(nèi)置的 delete 函數(shù),在執(zhí)行刪除操作時(shí),如果 Key 不存在也不會(huì)有異常
func main() { // 其余代碼保持不變 delete(info, "nickname") fmt.Printf("%p, %T, %v\n", info, info, info) delete(info, "weapon") fmt.Printf("%p, %T, %v\n", info, info, info) }
執(zhí)行上述代碼,輸出結(jié)果如下:
0xc000098180, map[string]string, map[address:NewYork balance: name:Tony Stark]
0xc000098180, map[string]string, map[address:NewYork balance: name:Tony Stark]
遍歷 Map 可以使用 for ... range
func main() { // 使用 Map 結(jié)構(gòu) 函數(shù)定義 Map info := map[string]string{ "name": "Stark", "address": "NewYork", } for k, v := range info { fmt.Println(k, ":", v) } }
執(zhí)行上述代碼,輸出結(jié)果如下:
name : Tony Stark
address : NewYork
Map 的遍歷是無序的
到此這篇關(guān)于Go 編程復(fù)雜數(shù)據(jù)類型 Map的文章就介紹到這了,更多相關(guān)Go Map內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Golang中切片長(zhǎng)度和容量的區(qū)別示例詳解
切片長(zhǎng)度與容量在Go中很常見,切片長(zhǎng)度是切片中可用元素的數(shù)量,而切片容量是從切片中第一個(gè)元素開始計(jì)算的底層數(shù)組中的元素?cái)?shù)量,這篇文章主要給大家介紹了關(guān)于Golang中切片長(zhǎng)度和容量區(qū)別的相關(guān)資料,需要的朋友可以參考下2024-01-01go單例實(shí)現(xiàn)雙重檢測(cè)是否安全的示例代碼
這篇文章主要介紹了go單例實(shí)現(xiàn)雙重檢測(cè)是否安全,本文給大家分享雙重檢驗(yàn)示例代碼,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03golang使用http client發(fā)起get和post請(qǐng)求示例
這篇文章主要介紹了golang使用http client發(fā)起get和post請(qǐng)求示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02Go語言設(shè)計(jì)模式之結(jié)構(gòu)型模式
本文主要聚焦在結(jié)構(gòu)型模式(Structural Pattern)上,其主要思想是將多個(gè)對(duì)象組裝成較大的結(jié)構(gòu),并同時(shí)保持結(jié)構(gòu)的靈活和高效,從程序的結(jié)構(gòu)上解決模塊之間的耦合問題2021-06-06再次探討go實(shí)現(xiàn)無限 buffer 的 channel方法
我們知道go語言內(nèi)置的channel緩沖大小是有上限的,那么我們自己如何實(shí)現(xiàn)一個(gè)無限 buffer 的 channel呢?今天通過本文給大家分享go實(shí)現(xiàn)無限 buffer 的 channel方法,感興趣的朋友一起看看吧2021-06-06