Go slice的底层实现原理?

2023-08-11 14:45:04 阅读:747 评论:0 点赞:0

切片是基于数组实现的,它的底层是数组,可以理解为对底层数组的抽象,其占用 24 个字节,包含数据指针(8字节)、切片的长度(8字节)、切片的容量(8字节)三个字段,数据结构如下:

type slice struct {
	array unsafe.Pointer
	len   int
	cap   int
}

array 指向底层数组的指针。
len 切片的长度。
cap 切片的容量,满足 cap >= len

切片的初始化方式

// 初始化方式1:直接声明
var slice1 []int

// 初始化方式2:使用字面量
slice2 := []int{1, 2, 3, 4}

// 初始化方式3:使用make创建slice
slice3 := make([]int, 3, 5)         

// 初始化方式4: 从切片或数组“截取”
slcie4 := arr[1:3]
标签: go 切片 slice

不拘一格

职业:后端开发工程师
学校:重庆师范大学
城市:重庆
文章:165
一个喜欢学习的人,快来和我成为朋友吧....

登录逐梦笔记

注册逐梦笔记

已有账号?