1.map的定义
go语言内置有map这种数据结构,它由无序的键值对组成,跟大部分语言中的map用法非常相似。
它的键不能由可变类型(引用语义)的结构类型担当,如切片、数组、函数等等。
map只有len
,没有cap
。
我们可以直接定义,或者通过make
函数创建,通过make
函数创建时,可以指定容量。
package main
import "fmt"
func main() {
// 无序结构,切片、函数、以及包含切片的结构类型(可变类型)由于具有引用语义,不能作为映射的键
var m1 map[int]string
fmt.Println("info = ", m1)
//对于map只有len,没有cap
fmt.Println("len = ", len(m1))
//可以通过make创建
m2 := make(map[int]string)
fmt.Println("m2 = ", m2)
fmt.Println("len = ", len(m2))
//可以通过make创建,指定容量
m3 := make(map[int]string, 10)
fmt.Println("m3 = ", m3)
fmt.Println("len = ", len(m3)) //长度依然为0
m3[123] = "am"
m3[245] = "is"
m3[1235] = "are"
fmt.Println(m3)
// 初始化操作
m4 := map[int]string{1: "am", 2: "is", 3: "are"}
fmt.Println(m4)
}
2.map的遍历
这里的遍历类似python字典的遍历,使用迭代器遍历,第一个值为key
,第二个值为value
,并且,迭代结果是无序的。
下面还给出了如何判断一个key值是否存在的方法,调用map
,会有2个返回值,第一个是value值,第二个是key值是否存在,若存在,则返回true
否则返回false
。
package main
import "fmt"
func main() {
mp1 := map[int]string{1: "a", 2: "b", 3: "c"}
//第一个返回值为key,第二个为value,迭代无序
for key, value := range mp1 {
fmt.Println(key, ":", value)
}
// 如何判断一个key值是否存在
// 第一个返回值为key所对应的value,第二个返回值为key是否存在的状态,存在为true,不存在为false
value, ok := mp1[1]
if ok == true {
fmt.Println("m[1] = ", value)
} else {
fmt.Println("key不存在")
}
}
3.map的赋值
map的赋值类似c语言和python的语言,具体操作如下,且容量不够时map
会进行自动扩容。
package main
import "fmt"
func main() {
mp1 := map[int]string{1: "a", 2: "b", 3: "c"}
fmt.Println("mp1 = ", mp1)
// 自动扩容
mp1[4] = "d"
fmt.Println("mp1 = ", mp1)
// 有重复值会覆盖前一个值
mp1[4] = "e"
fmt.Println("mp1 = ", mp1)
}
4.删除map的key值
我们可以使用delete
函数来删除map
中的值,第一个参数为map对象,第二个参数为要删除的键值对的key
值。
package main
import "fmt"
func main() {
m := map[int]string{1: "a", 2: "b", 3: "c"}
fmt.Println("m = ", m)
delete(m, 1) //删除key值为1的内容
fmt.Println("m = ", m)
}