你好哇,欢迎来答题,一起来看下昨天题目的解析:
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)
}
答案以及解析会在下一篇文章中给出,鼓励大家在留言区留下答案,抱团学习,日拱一卒,每天进步一点!
所有学习上的成功,都只依靠两件事 -- 策略和坚持,而坚持本身就是最重要的策略!
如果我的文章对你有所帮助,点赞、转发都是一种支持!