连 nil 切片和空切片一不一样都不分明?那 BAT 面试官只好让你回去等告诉了。
问题
package main
import (
"fmt"
"reflect"
"unsafe"
)
func main() {var s1 []int // nil 切片
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 切片和空切片最大的区别在于 指向的数组援用地址是不一样的。
- 所有的空切片指向的数组援用地址都是一样的
文章举荐:
- 昨天那个在 for 循环里 append 元素的共事,明天还在么?
- golang 面试官:for select 时,如果通道曾经敞开会怎么样?如果只有一个 case 呢?
- golang 面试官:for select 时,如果通道曾经敞开会怎么样?如果只有一个 case 呢?
- golang 面试题:对曾经敞开的的 chan 进行读写,会怎么样?为什么?
- golang 面试题:对未初始化的的 chan 进行读写,会怎么样?为什么?
- golang 面试题:reflect(反射包)如何获取字段 tag?为什么 json 包不能导出公有变量的 tag?
- golang 面试题:json 包变量不加 tag 会怎么样?
- golang 面试题:怎么防止内存逃逸?
- golang 面试题:简略聊聊内存逃逸?
- golang 面试题:字符串转成 byte 数组,会产生内存拷贝吗?
- golang 面试题:翻转含有中文、数字、英文字母的字符串
- golang 面试题:拷贝大切片肯定比小切片代价大吗?
- golang 面试题:能说说 uintptr 和 unsafe.Pointer 的区别吗?
如果你想每天学习一个知识点?