Go 面试每天一篇(第 71 天)

 

你好哇,公号正在举行答题送书活动,详情请看《自律改变自我,部落第 ① 期答题送书!》,今天是活动第 17 天,答题继续!

一起来看下昨天题目的解析:

1.关于字符串连接,下面语法正确的是?

  • A. str := 'abc' + '123'

  • B. str := "abc" + "123"

  • C. str := '123' + "abc"

  • D. fmt.Sprintf("abc%d", 123)

参考答案及解析:BD。知识点:单引号、双引号和字符串连接。在 Go 语言中,双引号用来表示字符串 string,其实质是一个 byte 类型的数组,单引号表示 rune 类型。

2.下面代码能编译通过吗?可以的话,输出什么?

 1func main() {
2
3    println(DeferTest1(1))
4    println(DeferTest2(1))
5}
6
7func DeferTest1(i int) (r int) {
8    r = i
9    defer func() {
10        r += 3
11    }()
12    return r
13}
14
15func DeferTest2(i int) (r int) {
16    defer func() {
17        r += i
18    }()
19    return 2
20}

参考答案及解析:43。具体解析请看《5 年 Gopher 都不知道的 defer 细节,你别再掉进坑里!》。

解析若有不妥之处,欢迎在留言区交流、指正!

看下今天的题目:

1.判断题:对变量x的取反操作是 ~x?

2.下面代码输出什么,请说明原因。

 1type Slice []int
2
3func NewSlice() Slice {
4    return make(Slice, 0)
5}
6func (s *Slice) Add(elem int) *Slice {
7    *s = append(*s, elem)
8    fmt.Print(elem)
9    return s
10}
11func main() {
12    s := NewSlice()
13    defer s.Add(1).Add(2)
14    s.Add(3)
15}

 

答案以及解析会在下一篇文章中给出,鼓励大家在留言区留下答案,抱团学习,日拱一卒,每天进步一点!

所有学习上的成功,都只依靠两件事 -- 策略和坚持,而坚持本身就是最重要的策略!

 

 

如果我的文章对你有所帮助,点赞、转发都是一种支持!

Go 面试每天一篇(第 71 天)

Go 面试每天一篇(第 71 天)

Go 面试每天一篇(第 71 天)
上一篇:leetcode 71 简化路径


下一篇:面试宝典:送上 71 道Java并发编程题(含全部参考答案)