Go语言在声明变量的时候,会自动对变量对应的内存区域进行初始化操作。每个变量会被初始化成其类型的默认值,例如:整型和浮点型变量的默认值为0。字符串变量的默认值为空字符串。布尔型变量默认为false。切片、函数、指针变量的默认为nil。
一个 nil 切片和空切片的定义如下
var s1 []int // nil切片
s2 := []int{} // 空切片,或者用 make([]int,0
好了,不能再多说了,再多说答案就出来了,接下来直接看问题。
问题
nil切片和空切片一样吗?如果不一样区别是什么,先看下下面这个描述问题的代码。
package main
import (
"fmt"
"reflect"
"unsafe"
)
func main() {
var s1 []int
s2 := make([]int,0)
s4 := make([]int,0)
fmt.Printf("s1 pointer:%+v, s2 pointer:%+v, s4 pointer:%+v, \n", *(*reflect.SliceHeader)(unsafe.Pointer(&s1)),*(*reflect.SliceHeader)(unsafe.Pointer(&s2)),*(*reflect.SliceHeader)(unsafe.Pointer(&s4)))
fmt.Printf("%v\n", (*(*reflect.SliceHeader)(unsafe.Pointer(&s1))).Data==(*(*reflect.SliceHeader)(unsafe.Pointer(&s2))).Data)
fmt.Printf("%v\n", (*(*reflect.SliceHeader)(unsafe.Pointer(&s2))).Data==(*(*reflect.SliceHeader)(unsafe.Pointer(&s4))).Data)
}
nil切片和空切片指向的地址一样吗?这个代码会输出什么?
怎么答
nil切片和空切片指向的地址不一样。nil空切片引用数组指针地址为0(无指向任何实际地址)
空切片的引用数组指针地址是有的,且固定为一个值
s1 pointer:{Data:0 Len:0 Cap:0}, s2 pointer:{Data:824634207952 Len:0 Cap:0}, s4 pointer:{Data:824634207952 Len:0 Cap:0},
false //nil切片和空切片指向的数组地址不一样
true //两个空切片指向的数组地址是一样的,都是824634207952
解释
之前在前面的文章里提到过切片的数据结构为
type SliceHeader struct {
Data uintptr //引用数组指针地址
Len int // 切片的目前使用长度
Cap int // 切片的容量
}
nil切片和空切片最大的区别在于指向的数组引用地址是不一样的。

所有的空切片指向的数组引用地址都是一样的

本篇面试题解,转载自公众号「小白debug」,如果喜欢它的文章内容,可以点击下方名片关注。
本文深入探讨了Go语言中nil切片与空切片的区别,通过对比它们的内存地址揭示了两者之间的关键不同之处,并提供了具体的代码示例来辅助理解。

被折叠的 条评论
为什么被折叠?



