你好哇,欢迎来答题,一起来看下昨天题目的解析:
1.下面的代码输出什么?
1type Point struct{ x, y int }
2
3func main() {
4 s := []Point{
5 {1, 2},
6 {3, 4},
7 }
8 for _, p := range s {
9 p.x, p.y = p.y, p.x
10 }
11 fmt.Println(s)
12}
参考答案及解析:输出 [{1 2} {3 4}]。知识点:for range 循环。range 循环的时候,获取到的元素值是副本,就比如这里的 p。修复代码示例:
1type Point struct{ x, y int }
2
3func main() {
4 s := []*Point{
5 &Point{1, 2},
6 &Point{3, 4},
7 }
8 for _, p := range s {
9 p.x, p.y = p.y, p.x
10 }
11 fmt.Println(*s[0])
12 fmt.Println(*s[1])
13}
2.下面的代码有什么隐患?
1func get() []byte {
2 raw := make([]byte, 10000)
3 fmt.Println(len(raw), cap(raw), &raw[0])
4 return raw[:3]
5}
6
7func main() {
8 data := get()
9 fmt.Println(len(data), cap(data), &data[0])
10}
参考答案及解析:get() 函数返回的切片与原切片公用底层数组,如果在调用函数里面(这里是 main() 函数)修改返回的切片,将会影响到原切片。为了避免掉入陷阱,可以如下修改:
1func get() []byte {
2 raw := make([]byte, 10000)
3 fmt.Println(len(raw), cap(raw), &raw[0])
4 res := make([]byte, 3)
5 copy(res, raw[:3])
6 return res
7}
8
9func main() {
10 data := get()
11 fmt.Println(len(data), cap(data), &data[0])
12}
解析若有不妥之处,欢迎在留言区交流、指正!
看下今天的题目:
1.关于map,下面说法正确的是?
-
A. map 反序列化时 json.unmarshal() 的入参必须为 map 的地址;
-
B. 在函数调用中传递 map,则子函数中对 map 元素的增加不会导致父函数中 map 的修改;
-
C. 在函数调用中传递 map,则子函数中对 map 元素的修改不会导致父函数中 map 的修改;
-
D. 不能使用内置函数 delete() 删除 map 的元素;
2.下面代码输出什么?请简要说明。
1type Foo struct {
2 val int
3}
4
5func (f Foo) Inc(inc int) {
6 f.val += inc
7}
8
9func main() {
10 var f Foo
11 f.Inc(100)
12 fmt.Println(f.val)
13}
答案以及解析会在下一篇文章中给出,鼓励大家在留言区留下答案,抱团学习,日拱一卒,每天进步一点!
所有学习上的成功,都只依靠两件事 -- 策略和坚持,而坚持本身就是最重要的策略!
如果我的文章对你有所帮助,点赞、转发都是一种支持!