前端之家收集整理的这篇文章主要介绍了
008.golang map,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
map
- 类似其它语言中的哈希表或者字典,以key-value形式存储数据
- Key必须是支持==或!=比较运算的类型,不可以是函数、map或slice
- Map查找比线性搜索快很多,但比使用索引访问数据的类型慢100倍
- Map使用make()创建,支持 := 这种简写方式
- make([keyType]valueType,cap),cap表示容量,可省略
- 超出容量时会自动扩容,但尽量提供一个合理的初始值
- 使用len()获取元素个数
- 键值对不存在时自动添加,使用delete()删除某键值对
- 使用 for range 对map和slice进行迭代操作
package main
import (
"fmt"
)
func main() {
var m map[int]string
m = make(map[int]string)
var m1 map[int]string = make(map[int]string)
m2 := make(map[int]string)
fmt.Println(m)
fmt.Println(m1)
fmt.Println(m2)
}
package main
import (
"fmt"
)
func main() {
m := make(map[int]string)
a := m[1]
fmt.Println(a)
m[3] = "Three"
b := m[3]
fmt.Println(b)
}
package main
import (
"fmt"
)
func main() {
var m map[int]map[int]string
m = make(map[int]map[int]string)
m[1] = make(map[int]string)
a,ok := m[1][1]
fmt.Println(ok)
if !ok {
m[1][1] = "OK"
}
a,ok = m[1][1]
fmt.Println(a,ok)
}
package main
import (
"fmt"
)
func main() {
sm := make([]map[int]string, 5)
for _,v := range sm {
v = make(map[int]string, 1)
v[1] = "OK"
fmt.Println(v)
}
fmt.Println(sm)
for i := range sm {
sm[i] = make(map[int]string, 1)
sm[i][1] = "OK"
fmt.Println(sm[i])
}
fmt.Println(sm)
}
package main
import (
"fmt"
)
func main() {
m := map[int]string{1: "a", 2: "b", 3: "c", 4: "d", 5: "e"}
s := make([]int,len(m))
i := 0
for k,_ := range m {
s[i] = k
i++
}
fmt.Println(s)
}
package main
import (
"fmt"
"sort"
)
func main() {
m := map[int]string{1: "a",_ := range m {
s[i] = k
i++
}
sort.Ints(s)
fmt.Println(s)
for k,_ := range s {
fmt.Println(m[k])
}
}