每次学习并整理一个Golang的知识点,每天进步一点点。今天学习下go中的一个知识点:map元素查找🤔

日省吾身

1.下面代码中 A B 两处应该怎么修改才能顺利编译?

1
2
3
4
5
6
7
func main() {
    var m map[string]int        //A
    m["a"] = 1
    if v := m["b"]; v != nil {  //B
        fmt.Println(v)
    }
}

2.写出下面代码片段的输出结果?

1
2
3
4
5
6
7
8
9
func main() {
	s := [3]string{"a", "b", "c"}
	s1 := s[:0]
	s2 := s[:2]
	s3 := s[1:2:cap(s)]
	fmt.Println("s1:", len(s1), cap(s1))
	fmt.Println("s2:", len(s2), cap(s2))
	fmt.Println("s3:", len(s3), cap(s3))
}

思考后看下方答案…

思考后看答案


答疑解惑

参考答案:

1. 原程序编译报错,改进后的程序示例如下:

1
2
3
4
5
6
7
8
9
func main() {
    // var m map[string]int        //A
    m := make(map[string]int)      //A改进
    m["a"] = 1
    // if v := m["b"]; v != nil {  //B
    if v, ok := m["b"]; ok {       //B改进
        fmt.Println(v)
    }
}

知识点:map

  • 在 A 处,只进行了map的声明,没有分配内存空间,即没有初始化,当前 m 是一个 nil map,不能直接赋值;go中推荐使用内置函数make()或字面量的方式进行map的初始化;
  • 在 B 处,从map中查找一个特定的值,推荐使用改进后的写法; 判断是否找到了特定的值,不需要检查取到的值是否为nil,只需查看第二个返回值ok;它是一个bool型,返回true表示找到了对应的数据;配合 := 操作符,减少代码冗余,看起来清晰易懂;

2. 程序的输出结果为:

1
2
3
s1: 0 3
s2: 2 3
s3: 1 2

知识点: 切片的创建

  • 基于数组切片,可以使用操作符创建新的切片,形如s[n:l:c],n是偏移的起始位置,l是偏移的长度结束,c是偏移的容量结束位置;l-n 就是新切片的长度, c-n 就是新切片的容量;如果n省略,默认为0
  • 有意思的是,n、l和c并不是当前切片的索引,所以l是可以超出当前切片的长度的,但不能超出当前切片的容量;比如假设oldSlice只有5个元素,但容量是10;newSlice却可以基于oldSlice的前7个元素创建,newSlice中超出oldSlice的部分都会填上0;

以上,你做对了吗?😊

其他相关答案或补充知识点,欢迎在评论区留言补充!

下期提问

  1. 判断下面代码片段的输出结果?
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
func incrementA() int {
	var n int
	defer func() {
		n++
	}()
	return n
}

func incrementB() (m int) {
	defer func() {
		m++
	}()
	return m
}

func main() {
	fmt.Println(incrementA())
	fmt.Println(incrementB())
}
  • A. 0 0
  • B. 0 1
  • C. 1 0
  • D. 1 1

答案及解析将在下期文章中给出,欢迎大家在评论区写出你的答案;独乐乐不如众乐乐,欢迎交流学习,互相进步。


欢迎转发和评论。更多优质原创文章,欢迎关注微信公众号“IYue爱月”或扫描下方二维码:

xujpxm_qrcode_gh