亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Go?編程復雜數(shù)據(jù)類型?Map

 更新時間:2022年08月19日 08:36:07   作者:RiemannHypothesis  
這篇文章主要介紹了Go編程復雜數(shù)據(jù)類型Map,Go中的Map是一組無需的K-V類型的數(shù)據(jù),與Python中的字典Dict和Java中的HashMap結構類似。未被初始化的Map為nil

一、Map 的定義

Go 中的 Map 是一組無需的 K-V 類型的數(shù)據(jù),與 Python 中的字典 Dict 和 Java 中的 HashMap 結構類似。未被初始化的 Map 為 nil。

// Map 的結構
map[string]string

Map 的定義

func main() {

   // 使用 Map 結構 函數(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í)行上述代碼,輸出結果如下:

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、指針和結構體等類型(支持 == 和 !=

切片不支持比較(切片只能和 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 {
}

接口和結構體可作為 Key,前提是所包含的屬性必須都是可以進行 == 或者 != 比較的,如果包含一個屬性不可以進行 == 或者 != 比較,便不能作為 Key。

二、Map 的操作

  • 增加或者修改鍵值對
  • 查詢,如果查詢的鍵不存在返回 空字符串
func main() {

   // 使用 Map 結構 函數(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"])

   // 添加一個空值的 KV
   info["balance"] = ""
   fmt.Println("余額屬性值是:", info["balance"])

}

執(zhí)行上述代碼,輸出結果如下:

0xc00010e180, map[string]string, map[address:NewYork name:Stark]
0xc00010e180, map[string]string, map[address:NewYork name:Tony Stark nickname:IRONMAN]
名字屬性值是: Tony Stark
技能屬性值是: 
余額屬性值是: 

根據(jù)上述代碼,查詢時如果 Key 不存在返回空字符串,如果 Key 的值是空字符串,那么查詢時返回的也是空字符串,顯然通過返回字符串是否為空來判斷 Key 是否存在是不準確的。

應該如何判斷 Key 是否存在?

Map 通過 [Key] 進行取值時會有兩個返回值,第一個值是 Key 對應的 Value,第二個值是布爾值,如果為 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í)行上述代碼,輸出結果如下:

weapon 屬性值是:, 是否存在:false
balance 屬性值是:, 是否存在:true

刪除 Key 需要使用到內(nèi)置的 delete 函數(shù),在執(zhí)行刪除操作時,如果 Key 不存在也不會有異常

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í)行上述代碼,輸出結果如下:

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 結構 函數(shù)定義 Map
   info := map[string]string{
      "name":    "Stark",
      "address": "NewYork",
   }

   for k, v := range info {
      fmt.Println(k, ":", v)
   }

}

執(zhí)行上述代碼,輸出結果如下:

name : Tony Stark
address : NewYork

Map 的遍歷是無序的

到此這篇關于Go 編程復雜數(shù)據(jù)類型 Map的文章就介紹到這了,更多相關Go  Map內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • GoLang函數(shù)與面向接口編程全面分析講解

    GoLang函數(shù)與面向接口編程全面分析講解

    這篇文章主要介紹了GoLang函數(shù)與面向接口編程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-01-01
  • Go語言接口用法實例

    Go語言接口用法實例

    這篇文章主要介紹了Go語言接口用法,實例分析了Go語言接口的功能、定義及使用技巧,需要的朋友可以參考下
    2015-02-02
  • Golang中切片長度和容量的區(qū)別示例詳解

    Golang中切片長度和容量的區(qū)別示例詳解

    切片長度與容量在Go中很常見,切片長度是切片中可用元素的數(shù)量,而切片容量是從切片中第一個元素開始計算的底層數(shù)組中的元素數(shù)量,這篇文章主要給大家介紹了關于Golang中切片長度和容量區(qū)別的相關資料,需要的朋友可以參考下
    2024-01-01
  • go單例實現(xiàn)雙重檢測是否安全的示例代碼

    go單例實現(xiàn)雙重檢測是否安全的示例代碼

    這篇文章主要介紹了go單例實現(xiàn)雙重檢測是否安全,本文給大家分享雙重檢驗示例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • golang使用http client發(fā)起get和post請求示例

    golang使用http client發(fā)起get和post請求示例

    這篇文章主要介紹了golang使用http client發(fā)起get和post請求示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-02-02
  • Go語言LeetCode題解1046最后一塊石頭的重量

    Go語言LeetCode題解1046最后一塊石頭的重量

    這篇文章主要為大家介紹了Go語言LeetCode題解1046最后一塊石頭的重量,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • go1.21中slog日志包用法入門

    go1.21中slog日志包用法入門

    go1.21中,slog這一被Go語言團隊精心設計的結構化日志包正式落地,本文將帶領讀者上手slog,體會其與傳統(tǒng)log的差異,感興趣的小伙伴快跟隨小編一起學習一下吧
    2023-09-09
  • Go語言設計模式之結構型模式

    Go語言設計模式之結構型模式

    本文主要聚焦在結構型模式(Structural Pattern)上,其主要思想是將多個對象組裝成較大的結構,并同時保持結構的靈活和高效,從程序的結構上解決模塊之間的耦合問題
    2021-06-06
  • 再次探討go實現(xiàn)無限 buffer 的 channel方法

    再次探討go實現(xiàn)無限 buffer 的 channel方法

    我們知道go語言內(nèi)置的channel緩沖大小是有上限的,那么我們自己如何實現(xiàn)一個無限 buffer 的 channel呢?今天通過本文給大家分享go實現(xiàn)無限 buffer 的 channel方法,感興趣的朋友一起看看吧
    2021-06-06
  • 詳解go?mod?使用方法

    詳解go?mod?使用方法

    golang 提供了 go mod命令來管理包,是go的一個模塊管理工具,用來代替?zhèn)鹘y(tǒng)的GOPATH方案,本文給大家介紹go?mod?使用方法,感興趣的朋友一起看看吧
    2022-05-05

最新評論