0
点赞
收藏
分享

微信扫一扫

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


你好哇,欢迎来答题,一起来看下​​昨天题目​​的解析:

1.下面的代码输出什么?

func main() {
var a []int = nil
a, a[0] = []int{1, 2}, 9
fmt.Println(a)
}

func main() {
var a []int = nil
a, a[0] = []int{1, 2}, 9
fmt.Println(a)
}

参考答案即解析:运行时错误。知识点:多重赋值。

多重赋值分为两个步骤,有先后顺序:

  • 计算等号左边的索引表达式和取址表达式,接着计算等号右边的表达式;
  • 赋值;

2.下面代码中的指针 p 为野指针,因为返回的栈内存在函数结束时会被释放?

type TimesMatcher struct {
base int
}

func NewTimesMatcher(base int) *TimesMatcher {
return &TimesMatcher{base:base}
}

func main() {
p := NewTimesMatcher(3)
fmt.Println(p)
}

type TimesMatcher struct {
base int
}

func NewTimesMatcher(base int) *TimesMatcher {
return &TimesMatcher{base:base}
}

func main() {
p := NewTimesMatcher(3)
fmt.Println(p)
}

  • A. false
  • B. true

参考答案及解析:A。Go语言的内存回收机制规定,只要有一个指针指向引用一个变量,那么这个变量就不会被释放(内存逃逸),因此在 Go 语言中返回函数参数或临时变量是安全的。

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

看下今天的题目:

1.下面这段代码输出什么?

func main() {
count := 0
for i := range [256]struct{}{} {
m, n := byte(i), int8(i)
if n == -n {
count++
}
if m == -m {
count++
}
}
fmt.Println(count)
}

func main() {
count := 0
for i := range [256]struct{}{} {
m, n := byte(i), int8(i)
if n == -n {
count++
}
if m == -m {
count++
}
}
fmt.Println(count)
}

引自《Go语言101》

2.下面代码输出什么?

const (
azero = iota
aone = iota
)

const (
info = "msg"
bzero = iota
bone = iota
)

func main() {
fmt.Println(azero, aone)
fmt.Println(bzero, bone)
}

const (
azero = iota
aone = iota
)

const (
info = "msg"
bzero = iota
bone = iota
)

func main() {
fmt.Println(azero, aone)
fmt.Println(bzero, bone)
}

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

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

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

Go 面试每天一篇(第 82 天)_赋值

Go 面试每天一篇(第 82 天)_内存回收_02

举报

相关推荐

0 条评论