每次学习并整理一个Golang的知识点,每天进步一点点。今天学习下go中的一个知识点: map元素查找
日省吾身
1.下面代码中 A B 两处应该怎么修改才能顺利编译?
func main() {
var m map[string]int //A
m["a"] = 1
if v := m["b"]; v != nil { //B
fmt.Println(v)
}
}
2.写出下面代码片段的输出结果?
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. 原程序编译报错,改进后的程序示例如下:
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. 程序的输出结果为:
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;
以上,你做对了吗?
其他相关答案或补充知识点,欢迎在评论区留言补充!
下期提问
- 判断下面代码片段的输出结果?
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爱月”。