本文轉自:https://www.cnblogs.com/demon89/p/7259724.html
Map 是一種無序的索引值對的集合。Map 最重要的一點是通過 key 來快速檢索資料,key 類似於索引,指向資料的值。
Map 是一種集合,所以我們可以像迭代數組和切片那樣迭代它。不過,Map 是無序的,我們無法決定它的返回順序,這是因為 Map 是使用 hash 表來實現的。
所以在golang中Map的遍曆不像其他語言一樣,它的輸出是無序的func traversal() { tmap := make(map[int]string) tmap[0] = "a" tmap[1] = "b" tmap[2] = "c" tmap[3] = "d" tmap[4] = "e" tmap[5] = "f" tmap[6] = "g" tmap[7] = "h" for k, v := range tmap { fmt.Printf("k:%d,v:%s\n", k, v) }}output:k:2,v:ck:3,v:dk:4,v:ek:5,v:fk:6,v:gk:7,v:hk:0,v:ak:1,v:b
原文老哥他就很想按順序列印
//建立mapcountryCapitalMap := map[string] string {"France":"Paris","Italy":"Rome","Japan":"Tokyo","India":"New Delhi"}country_array := [] string {"France","Italy","Japan","India"} //根據自訂的數組的順序有序的列印map中的資訊for _,country := range country_array{ fmt.Printf("Capital %v of is %v \n",country,countryCapitalMap[country])}
然後看到老哥這麼倔強,我就順道看了一下如何排序一個map
其實思路還是一樣的,只能用slice曲線救國。
func main() { m := map[string]int{ "something": 10, "yo": 20, "blah": 20, } type kv struct { Key string Value int } var ss []kv for k, v := range m { ss = append(ss, kv{k, v}) } sort.Slice(ss, func(i, j int) bool { return ss[i].Value > ss[j].Value // 降序 // return ss[i].Value < ss[j].Value // 升序 }) for _, kv := range ss { fmt.Printf("%s, %d\n", kv.Key, kv.Value) }}
定義 Map
可以使用內建函數 make 也可以使用 map 關鍵字來定義 Map:
聲明變數,預設map是nilvar map_name = map[type]type另外一種使用make建立map_name := make(map[type]type)
如果不初始化 map,那麼就會建立一個 nil map。nil map 不能用來存放索引值對
個人認為常用且值得注意的一點是,判斷key是否存在於map
//查看元素是否在map中,變數ok會返回true或者false,//當查詢的key在map中則返回true並且captial會擷取到map中的值captial, ok := countryCapitalMap["United States"]if ok{ fmt.Println("Capital of",captial,"is",countryCapitalMap[captial])}else{ fmt.Println("Capital of United States is not present")}