map使用make()創(chuàng)建,支持:=這種簡寫方式
專注于為中小企業(yè)提供網(wǎng)站制作、成都網(wǎng)站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)巴彥免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了近千家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。使用len()獲取元素個數(shù)
1、map[K]V
2、map[K1]map[K2]V 復合map,也就是說,值value也是map類型
//map 練習
package main
import (
"fmt"
"sort"
)
func main() {
//============================方式一:===========================
//創(chuàng)建一個空的map
//先聲明一個map類型
var nodeMap map[int]string
//初始化nodeMap, 全部為空
nodeMap = map[int]string{}
fmt.Println(nodeMap)
fmt.Println("-----------------------------------------------")
//============================方式二:===========利用make================
var clusterMap map[int]string = make(map[int]string)
fmt.Println(clusterMap)
fmt.Println("-----------------------------------------------")
//============================方式三:===========利用推斷功能================
operatorMap := make(map[int]string)
fmt.Println(operatorMap)
//============================方式四:===========創(chuàng)建時直接初始化================
//此種方式,不需要使用make
operatorMap2 := map[int]string{3:"hello", 5:"world"}
fmt.Println("===>:\t",operatorMap2)
// ======初始化=====
nodeMap[1] = "sparkNode"
nodeMap[2] = "esNode"
fmt.Println(nodeMap)
//=======根據(jù)鍵 取出 元素
nodeName := nodeMap[2]
fmt.Println(nodeName)
//======刪除鍵值對
delete(nodeMap, 1) //根據(jù)鍵值對,進行刪除
fmt.Println(nodeMap)
fmt.Println("-----------------------------------------------")
//--------------復雜map的操作-------------------
//聲明一個map類型
var clusterAppTaskId map[string]map[string]string
//初始化此map類型
clusterAppTaskId = make(map[string]map[string]string)
taskId, ok := clusterAppTaskId["spark-beijing"]["/spark-beijing/app-uewqr"]
if !ok {
//每一級別的map都有進行初始化,編譯時是找不到的,只有運行時,才能發(fā)現(xiàn)
clusterAppTaskId["spark-beijing"] = make(map[string]string)
}
clusterAppTaskId["spark-beijing"]["/spark-beijing/app-uewqr"] = "app-ewr-spark-taskid-001"
taskId, ok = clusterAppTaskId["spark-beijing"]["/spark-beijing/app-uewqr"]
fmt.Println(taskId, ok)
fmt.Println("-----------------------------------------------")
//--------------迭代操作-------------------
//for i, v := range slice {
//
//}
//i, 表示下標,v表示對應的值,是拷貝的值
//要特別注意,對v的任何修改,都不影響原值,
// map類型也是,不會影響原值的
//例如,下面的例子,就是對v的操作后,不會對sm產(chǎn)生影響的
//因此,不建議使用這種方式
sm := make([]map[int]string, 5)
for _, v := range sm {
v = make(map[int]string)
v[1] = "ok"
fmt.Println(v)
}
fmt.Println(sm)
fmt.Println("-----------------------------------------------")
//下面的修改,原值
for i := range sm {
sm[i] = make(map[int]string)
sm[i][2] = "spark"
fmt.Println(sm[i])
}
fmt.Println(sm)
fmt.Println("-----------------------------------------------")
//---------------------------------
//map是無序的,如何按照鍵從小到大獲取map中的值
//需要生成一個切片,來存儲map的鍵
//將鍵按照從小到大排序,然后,再根據(jù)鍵去取值
marathonApp := map[int]string{1: "spark", 3: "es", 8: "ftp", 7:"hadoop", 4: "k8s", 2: "docker"}
len := len(marathonApp)
//生成一個切片,來存儲鍵
kSlice := make([]int, len)
// 聲明一個計數(shù)器,用于初始化切片時使用
var i int = 0
for k, _ := range marathonApp {
kSlice[i] = k
i++
}
fmt.Println("鍵排序前:\t", kSlice)
//切片是引用傳遞,因此,下面排序后,不需要返回值進行接收
sort.Ints(kSlice)
fmt.Println("鍵排序后:\t", kSlice)
fmt.Println("根據(jù)鍵按照從小到大,依次取出對應的值")
//下面,開始迭代marathonApp,就可以按照鍵的從小到大,依次取出值了
for _, v := range kSlice {
//這里一定要注意,是用值,而不是 kSlice的下標
fmt.Println(marathonApp[v])
}
}
//測試某個值是否在map里呢?
package main
import "fmt"
func main() {
sparkClusterIdApp := map[string]string{"spark001":"marathon001","spark002":"marathon002"}
clusterId001 := "spark003"
_, ok := sparkClusterIdApp[clusterId001]
if !ok {
fmt.Println("clusterId: \t", clusterId001, "不再容器里")
}
clusterId002 := "spark001"
if v,ok :=sparkClusterIdApp[clusterId002]; ok {
fmt.Println("value:\t", v)
} else {
fmt.Println("value does not exist!")
}
}
測試結(jié)果:
clusterId: spark003 不再容器里
value: marathon001
Process finished with exit code 0
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。