func TestInitMap(t *testing.T) {
m1 := map[int]int{1: 1, 2: 4, 3: 9}
t.Log(m1[2]) // 4
t.Log(len(m1)) // 3
m2 := map[int]int{}
m2[4] = 16
t.Log(len(m2)) // 1
// 10为cap,没有使用len,因为len会初始化为“0”值,但map没法预设“0”值
m3 := make(map[int]int, 10)
t.Log(len(m3)) // 0
//t.Log(cap(m3)) // invalid argument m3 (type map[int]int) for cap
}
元素访问
func TestAccessNotExistingKey(t *testing.T) {
m1 := map[int]int{}
// 不存在,返回0,避免了其他语言中的空指针异常
t.Log(m1[1]) // 0
m1[2] = 0
// 存在0,返回0,无法区分
t.Log(m1[2]) // 0
if v, ok := m1[3]; ok {
t.Log("Key exists, value=", v)
} else {
t.Log("Key not exists ")
}
}
遍历
func TestTravelMap(t *testing.T) {
m := map[int]int{1: 1, 2: 4, 3: 9}
for k, v := range m {
t.Log(k, v)
// 1 1
// 2 4
// 3 9
}
}
工厂模式
- Map的value可以是一个 方法
- 与 Go 的 Dock type 接口方式一起,可以方便地实现 单一方法对象的工厂模式
- 在Go语言, 函数是一等公民
func TestMapWithFunValue(t *testing.T) {
m := map[int]func(op int) int{}
m[1] = func(op int) int { return op }
m[2] = func(op int) int { return op * op }
m[3] = func(op int) int { return op * op * op }
t.Log(m[1](2), m[2](2), m[3](2)) // 2 4 8
}
实现Set
- Go的内置集合没有Set实现 ,可以使用 map[type]bool
- 元素的 唯一性
- 基本操作:添加元素、判断元素是否存在、删除元素、元素个数
func TestMapForSet(t *testing.T) {
mySet := map[int]bool{}
n := 1
mySet[n] = true
if mySet[n] {
t.Logf("%d is exists", n) // 1 is exists
} else {
t.Logf("%d is not exists", n)
}
mySet[2] = true
t.Log(len(mySet)) // 2
delete(mySet, 1)
if mySet[n] {
t.Logf("%d is exists", n)
} else {
t.Logf("%d is not exists", n) // 1 is not exists
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
民事诉讼程序研究
乔罗威茨 / 吴泽勇 / 2008-6 / 40.00元
《民事诉讼程序研究》共分为诉讼程式;扩散利益、分散利益和集体利益的保护;程式样式;当事人与法官;对判決的救济;程式改革。主要內容包括:民事诉讼;英美民事诉讼程式在20世纪的若干发展;论民事诉讼法的本质和目的等。一起来看看 《民事诉讼程序研究》 这本书的介绍吧!