Map 是一种无序的键值对的集合。
Map 最重要的一点是通过 key 来快速检索数据,key 类似于索引,指向数据的值。
Map 是一种集合,所以我们可以像迭代数组和切片那样迭代它。不过,Map 是无序的,我们无法决定它的返回顺序,
这是因为 Map 是使用 hash 表来实现的
下面看具体实例:
package main
import (
"fmt"
)
// func myPrint(a map) {
// fmt.Printf("T=%T v=%v \n",a,a)
// }
func main() {
fmt.Println("ok")
// 定义map的方法
/*
声明变量,默认 map 是 nil
var map_variable map[key_data_type]value_data_type
使用 make 函数
map_variable := make(map[key_data_type]value_data_type)
*/
var new_map map[string]string
new_map = make(map[string]string) // 必须要这样创建的原因,因此使用切片的方法使这个集合可以在后面再被增加操作
// 如果不初始化 map,那么就会创建一个 nil map。nil map 不能用来存放键值对
// 下面就是进行了初始化操作的map
new_map1 := map[string]string{
"name":"asd",
}
var countryCapitalMap map[string]string /*创建集合 */
countryCapitalMap = make(map[string]string)
new_map ["test"] = "aea"
new_map ["new"] = "26"
fmt.Println(new_map)
// 并且这个初始化的map;可以可以再增加的
new_map1["age"] = "28"
fmt.Println(new_map1)
/* map插入key - value对,各个国家对应的首都 */
countryCapitalMap [ "France" ] = "Paris"
countryCapitalMap [ "Italy" ] = "罗马"
countryCapitalMap [ "Japan" ] = "东京"
countryCapitalMap [ "India " ] = "新德里"
fmt.Println(countryCapitalMap)
for country := range countryCapitalMap {
fmt.Println(country, "首都是", countryCapitalMap [country])
}
/*查看元素在集合中是否存在 */
captial, ok := countryCapitalMap [ "美国" ] /*如果确定是真实的,则存在,否则不存在 */
fmt.Println(captial) // 因为不存在,所以返回一个空
fmt.Println(ok)
if (ok) {
fmt.Println("美国的首都是", captial)
} else {
fmt.Println("美国的首都不存在")
}
// 使用delete函数删除map里面的值
delete(countryCapitalMap,"Japan")
fmt.Println(countryCapitalMap)
}