!!!!!!!!!!!!!!! http://studygolang.com/pkgdoc 非常好的一个标准库网站
01、map 定义
--定义:map是一种w无序的基于key-value的数据结构,map是引用类型,必须初始化才能使用
--map也是动态扩容的,需要初始化容器大小的
--形式:
--map[KeyType]ValueType
--KeyType:表示键的类型
--ValueType:表示键对应的值的类型
--map类型的变量默认初始值为nil,需要使用make()函数来分配内存。语法为:
--make(map[KeyType]ValueType, [cap])
--其中cap表示map的容量,该参数虽然不是必须的,但是我们应该在初始化map的时候就为其指定一个合适的容量
--代码示例如下:
var m1 map[string]int // 初始化
m1 = make(map[string]int, 10) // 分配内存
fmt.Println(m1 == nil) // 不分配map会报此错误 ==> panic: assignment to entry in nil map
m1["理想"] = 18
m1["姬无名"] = 35
fmt.Println(m1) // map[姬无名:35 理想:18]
02、从 map 数据类型 及 验证是否存在
--使用 v, ok 接受map查询结果
var m1 map[string]int // 初始化
m1 = make(map[string]int, 10) // 分配内存
m1["理想"] = 18
m1["姬无名"] = 35
// 验证是否存在 "娜扎" 这个值
v, ok := m1["娜扎"]
if !ok {
fmt.Println("经查证确无此人")
} else {
fmt.Println(v)
}
03、map遍历
--哈哈哈,无师自通,和python真的像,除了不能默认初始化之外
var rangemap map[string]string
rangemap = make(map[string]string, 10)
rangemap["江苏"] = "苏州"
rangemap["福建"] = "福州"
rangemap["安徽"] = "安庆"
//遍历 k, v
for k, v := range rangemap {
fmt.Println(k, v)
}
//只遍历 key
for k := range rangemap{
}
//只遍历value
for _, v := range rangemap{
}
******************** 输出结果 ************************
江苏 苏州
福建 福州
安徽 安庆
04、删除map中元素值
--删除元素中map值:
var rangemap map[string]string
rangemap = make(map[string]string, 10)
rangemap["江苏"] = "苏州"
rangemap["福建"] = "福州"
rangemap["安徽"] = "安庆"
rangemap["河北"] = "保定"
fmt.Println(rangemap)
// 删除map中元素
// 值得注意的是,这里如果删除的元素不存在于map之中不会报错只是会不处理罢了
delete(rangemap, "河北")
fmt.Println(rangemap)
--注:delete函数在内置库的builtin中,built和fmt一样是内置库
05、一个小小的汇总应用 -- 间隔一段时间之后再看map时的感触
package main
import "fmt"
func main() {
var m1 map[string]string
m1 = make(map[string]string, 10) // 1、必须在初始化之后给map分配内存空间大小
m1["name"] = "liming"
m1["age"] = "35"
// 检查键值是否存在方式一
value, ok := m1["age"]
if !ok { // 2、ok是键值,这一点和其他的顺序不同
fmt.Println("查无此 key")
} else {
fmt.Println(value)
}
// 检查键值是否存在方式二
// fmt.Println(m1["birthday"]) 如果为空不会报错,其输出为0[int] 或 “”[string]
}
06、生成一个随机的map,对map的key排序之后,按照对应简直关系输出排序好之后的新的map
package main
import (
"fmt"
"math/rand"
"sort"
"time"
)
func main() {
rand.Seed(time.Now().UnixNano()) //初始化随机数种子
var scoreMap = make(map[string]int, 200)
for i := 0; i < 100; i++ {
key := fmt.Sprintf("stu%02d", i) //生成stu开头的字符串
value := rand.Intn(100) //生成0~99的随机整数
scoreMap[key] = value
}
//取出map中的所有key存入切片keys
var keys = make([]string, 0, 200)
for key := range scoreMap {
keys = append(keys, key)
}
//对切片进行排序
sort.Strings(keys)
//按照排序后的key遍历map
for _, key := range keys {
fmt.Println(key, scoreMap[key])
}
}
07、map 和 slice的互相嵌套 -- 列表中含有字典 以及 字典中元素为列表
--按照python来理解就是:
--[{}, {}, {}, ......]
--{
"":[],
"":[],
... ...
}
--代码示例如下:
package main
// 元素类型为map的字典,即列表中含字典
import (
"fmt"
)
func main() {
// 01、切片中元素为map
// var s1 = make([]map[int]string, 0, 10) // 定义一个切片,元素为map,切片长度为0,容量为10
var s1 = make([]map[int]string, 10, 10)
// 这里有一个大坑,就是我们只初始化了slice,没有初始化每个map元素
// s1[0][100] = "liming" // 会报错 panic: index out of range 因为这里长度设置为0,因此这种情况下长度一般和容量一致
// 当设置了长度为10以后会报错 panic: assignment to entry in nil map,即没有分配容量给map
// 先分配内存,再使用
s1[0] = make(map[int]string, 1)
s1[0][0] = "liming"
fmt.Println(s1[0][0]) // liming
fmt.Println(s1[0]) // map[0:liming]
fmt.Println(s1) // [map[0:liming] map[] map[] map[] map[] map[] map[] map[] map[] map[]]
// 02、map中含有切片
var m1 = make(map[string][]int, 10) // 定义一个map, 其value为int的slice类型,容量为10
m1["北京"] = []int{10, 20, 30}
fmt.Println(m1)
}