欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

9個(gè)Golang中map常用示例分享

 更新時(shí)間:2023年02月16日 15:58:35   作者:TtrOps  
這篇文章主要和大家分享9個(gè)Golang中map可能是常用的使用案例,從1到9,越來越厲害。文中的示例代碼講解詳細(xì),希望對(duì)大家學(xué)習(xí)Golang有一定的幫助

1.基本使用

package?main

import?(
?"fmt"
)

func?main()?{
?stu?:=?make(map[string]int,?2)
?stu["xiaoming"]?=?25
?stu["xiaohua"]?=?23
?fmt.Println(stu)
?fmt.Println(stu["xiaoming"])
?fmt.Printf("type?of?a:?%T",?stu)
}

輸出:

map[xiaohua:23 xiaoming:25]
25
type of a: map[string]int

2.聲明的同時(shí)一起初始化

package?main

import?(
?"fmt"
)

func?main()?{

?stu?:=?map[string]int{
??"xiaoming":?25,
??"xiaohua":??22,
?}
?fmt.Println(stu)
?fmt.Println(stu["xiaoming"])
?fmt.Println(stu["xiaohua"])
}

輸出:

map[xiaohua:22 xiaoming:25]
25
22

3.判斷key是否存在

package?main

import?(
?"fmt"
)

func?main()?{

?stu?:=?map[string]int{
??"xiaoming":?25,
??"xiaohua":??22,
?}

?v1,?result1?:=?stu["xiaoming"]
?v2,?result2?:=?stu["xiaohuang"]
?fmt.Println(result1,?v1)
?fmt.Println(result2,?v2)

?if?result1?{
??fmt.Println("yes")
?}?else?{
??fmt.Println("no")
?}

?if?result2?{
??fmt.Println("yes")
?}?else?{
??fmt.Println("no")
?}
}

輸出:

true 25
false 0
yes
no

如果key存在,則result1為true,否則反之,可見result2。

4.遍歷map

package?main

import?(
?"fmt"
)

func?main()?{
?stu?:=?map[string]int{
??"xiaoming":??25,
??"xiaohua":???22,
??"xiaozhang":?23,
??"xiaoshi":???21,
??"xiaoyu":????18,
?}
?for?k,?v?:=?range?stu?{
??fmt.Println(k,?v)
?}
}

輸出:

xiaoming 25
xiaohua 22
xiaozhang 23
xiaoshi 21
xiaoyu 18

也可以只遍歷key

for?k?:=?range?stu?{
????fmt.Println(k)
}

5.刪除k-v對(duì)

使用內(nèi)置的delete函數(shù)進(jìn)行刪除

package?main

import?(
?"fmt"
)

func?main()?{
?stu?:=?map[string]int{
??"xiaoming":??25,
??"xiaohua":???22,
??"xiaozhang":?23,
??"xiaoshi":???21,
??"xiaoyu":????18,
?}
?fmt.Println(stu)
?delete(stu,?"xiaoshi")
?fmt.Println(stu)
}

輸出:

map[xiaohua:22 xiaoming:25 xiaoshi:21 xiaoyu:18 xiaozhang:23]
map[xiaohua:22 xiaoming:25 xiaoyu:18 xiaozhang:23]

6.map是無序的,如何讓其按照指定的順序遍歷map

「無序的遍歷演示」

package?main

import?(
?"fmt"
?"math/rand"
?"time"
)

func?main()?{
?rand.Seed(time.Now().UnixNano())

?var?hostMap?=?make(map[string]string,?10)

?for?i?:=?0;?i?<?10;?i++?{
??key?:=?fmt.Sprintf("host%02d",?i)
??value?:=?rand.Intn(100)
??ip?:=?fmt.Sprintf("10.1.1.%d",?value)
??hostMap[key]?=?ip
?}
?for?k,?v?:=?range?hostMap?{
??fmt.Println(k,?v)
?}
}

輸出:

host03 10.1.1.32
host00 10.1.1.0
host02 10.1.1.37
host05 10.1.1.97
host06 10.1.1.61
host07 10.1.1.62
host08 10.1.1.28
host09 10.1.1.40
host01 10.1.1.62
host04 10.1.1.70

注意到了嗎?map是無序的。雖然host01-host09是有順序的賦給了map,但遍歷取值的時(shí)候就不是有序了。而且,每一次遍歷的順序都不同。

「實(shí)現(xiàn)有序的遍歷」

package?main

import?(
?"fmt"
?"math/rand"
?"sort"
?"time"
)

func?main()?{
?rand.Seed(time.Now().UnixNano())

?var?hostMap?=?make(map[string]string,?10)

?for?i?:=?0;?i?<?10;?i++?{
??key?:=?fmt.Sprintf("host%02d",?i)
??value?:=?rand.Intn(100)
??ip?:=?fmt.Sprintf("10.1.1.%d",?value)
??hostMap[key]?=?ip
?}

?var?hostSlice?=?make([]string,?0,?200)

?//?將hostMap中的key追加到hostSlice(切片)
?for?k?:=?range?hostMap?{
??hostSlice?=?append(hostSlice,?k)
?}

?//?使用內(nèi)置的sort函數(shù)對(duì)切片(hostSlice)進(jìn)行排序(基于key進(jìn)行排序,剛剛已經(jīng)把key追加到了切片中)
?sort.Strings(hostSlice)

?for?_,?k?:=?range?hostSlice?{
??fmt.Println(k,?hostMap[k])
?}
}

輸出:

host00 10.1.1.87
host01 10.1.1.98
host02 10.1.1.93
host03 10.1.1.4
host04 10.1.1.1
host05 10.1.1.28
host06 10.1.1.11
host07 10.1.1.43
host08 10.1.1.31
host09 10.1.1.83

7.map作為元素存儲(chǔ)到切片中

package?main

import?(
?"fmt"
)

func?main()?{
?//?創(chuàng)建一個(gè)存儲(chǔ)map類型元素的切片,最大擴(kuò)張容量為3
?dataSlice?:=?make([]map[string]string,?3)
?fmt.Println(dataSlice)

?fmt.Println("------------")
?//?在切片的索引0位置創(chuàng)建一個(gè)key和value都為string類型的map,容量為2
?dataSlice[0]?=?make(map[string]string,?2)
?//?給切片的索引0位置,賦map類型的數(shù)據(jù),key為user,value為root
?dataSlice[0]["user"]?=?"root"
?dataSlice[0]["pwd"]?=?"abc123"
?fmt.Println(dataSlice)

?fmt.Println("------------")
?for?i?:=?range?dataSlice?{
??fmt.Println(dataSlice[i])
?}

?fmt.Println("------------")
?for?i?:=?range?dataSlice?{
??fmt.Println(dataSlice[i]["user"],?dataSlice[i]["pwd"])
?}
}

輸出:

[map[] map[] map[]]
------------
[map[pwd:abc123 user:root] map[] map[]]
------------
map[pwd:abc123 user:root]
map[]
map[]
------------
root abc123

上面例子,只在切片的索引0位置存儲(chǔ)了map元素,索引1和2沒有。

8.切片作為map的value,map的key為字符串

package?main

import?"fmt"

func?main()?{
?//?聲明字符串類型的切片和初始化了兩個(gè)值
?value?:=?[]string{"192.168.10.12",?"10.1.1.23"}

?//聲明key類型為字符串,value類型為切片的map,并初始化了一對(duì)key和value
?data?:=?map[string][]string{
??"ip":?value,
?}
?fmt.Println(data)
?fmt.Println(data["ip"])
}

輸出:

map[ip:[192.168.10.12 10.1.1.23]]
[192.168.10.12 10.1.1.23]

9.map作為map的value

package?main

import?"fmt"

func?main()?{
?value?:=?map[string]string{
??"管理IP":?"10.1.2.39",
??"業(yè)務(wù)IP":?"192.168.12.56",
?}

?a?:=?map[string]map[string]string{
??"nginx":?value,
?}

?fmt.Println(a)
?fmt.Println(a["nginx"])
?fmt.Println(a["nginx"]["管理IP"])
?fmt.Println(a["nginx"]["業(yè)務(wù)IP"])
}

輸出:

map[nginx:map[業(yè)務(wù)IP:192.168.12.56 管理IP:10.1.2.39]]
map[業(yè)務(wù)IP:192.168.12.56 管理IP:10.1.2.39]
10.1.2.39
192.168.12.56

到此這篇關(guān)于9個(gè)Golang中map常用示例分享的文章就介紹到這了,更多相關(guān)Golang map內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 使用Go語言構(gòu)建高效的二叉搜索樹聯(lián)系簿

    使用Go語言構(gòu)建高效的二叉搜索樹聯(lián)系簿

    樹是一種重要的數(shù)據(jù)結(jié)構(gòu),而二叉搜索樹(BST)則是樹的一種常見形式,在本文中,我們將學(xué)習(xí)如何構(gòu)建一個(gè)高效的二叉搜索樹聯(lián)系簿,感興趣的可以了解下
    2024-01-01
  • 細(xì)細(xì)探究Go 泛型generic設(shè)計(jì)

    細(xì)細(xì)探究Go 泛型generic設(shè)計(jì)

    這篇文章主要帶大家細(xì)細(xì)探究了Go 泛型generic設(shè)計(jì)及示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 深入分析Go?實(shí)現(xiàn)?MySQL?數(shù)據(jù)庫事務(wù)

    深入分析Go?實(shí)現(xiàn)?MySQL?數(shù)據(jù)庫事務(wù)

    本文深入分析了Go語言實(shí)現(xiàn)MySQL數(shù)據(jù)庫事務(wù)的原理和實(shí)現(xiàn)方式,包括事務(wù)的ACID特性、事務(wù)的隔離級(jí)別、事務(wù)的實(shí)現(xiàn)方式等。同時(shí),本文還介紹了Go語言中的事務(wù)處理機(jī)制和相關(guān)的API函數(shù),以及如何使用Go語言實(shí)現(xiàn)MySQL數(shù)據(jù)庫事務(wù)。
    2023-06-06
  • 基于Go語言實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器

    基于Go語言實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了如何基于Go語言實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器,文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起了解一下
    2023-10-10
  • golang?pprof?監(jiān)控goroutine?thread統(tǒng)計(jì)原理詳解

    golang?pprof?監(jiān)控goroutine?thread統(tǒng)計(jì)原理詳解

    這篇文章主要為大家介紹了golang?pprof?監(jiān)控goroutine?thread統(tǒng)計(jì)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • golang不到30行代碼實(shí)現(xiàn)依賴注入的方法

    golang不到30行代碼實(shí)現(xiàn)依賴注入的方法

    這篇文章主要介紹了golang不到30行代碼實(shí)現(xiàn)依賴注入的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • GO語言求100以內(nèi)的素?cái)?shù)

    GO語言求100以內(nèi)的素?cái)?shù)

    這篇文章主要介紹了GO語言求100以內(nèi)的素?cái)?shù),主要通過篩選法來實(shí)現(xiàn),涉及GO語言基本的循環(huán)與函數(shù)調(diào)用方法,需要的朋友可以參考下
    2014-12-12
  • go語言工程結(jié)構(gòu)

    go語言工程結(jié)構(gòu)

    這篇文章主要簡(jiǎn)單介紹了go語言工程結(jié)構(gòu),對(duì)于我們學(xué)習(xí)go語言很有幫助,需要的朋友可以參考下
    2015-01-01
  • Golang打包配置文件的實(shí)現(xiàn)示例

    Golang打包配置文件的實(shí)現(xiàn)示例

    本文主要介紹了Golang打包配置文件的實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • go 壓縮解壓zip文件源碼示例

    go 壓縮解壓zip文件源碼示例

    這篇文章主要為大家介紹了go壓縮及解壓zip文件的源碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07

最新評(píng)論