go语言的切片理解

Go 复制代码
var numbers4 = [...]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
	myslice := numbers4[4:6]
	//这打印出来长度为2
	fmt.Printf("myslice为 %d, 其长度为: %d\n", myslice, len(myslice))
	myslice = myslice[:cap(myslice)]
	//为什么 myslice 的长度为2,却能访问到第四个元素
	fmt.Printf("myslice的第四个元素为: %d", myslice[3])

为什么打印cap(mysslice) 等于6?

在 Go 语言中,切片的容量是从切片的第一个元素开始到底层数组末尾元素的个数。当你从数组 numbers4 中创建切片 myslice 时,虽然你只选择了索引4到索引6(不包括索引6)的元素,但是 myslice 的底层数组仍然是 numbers4,所以 myslice 的容量是从 numbers4 数组的第5个元素开始到 numbers4 数组末尾的元素个数,因此 cap(myslice) 的结果是6。

相关推荐
IT方大同6 分钟前
C语言的组成部分
c语言·开发语言
BINGCHN6 分钟前
流量分析进阶(一):RCTF2025-Shadows of Asgard
开发语言·python
G***669124 分钟前
Java区块链开发
java·开发语言·区块链
自由生长202424 分钟前
Protocol Buffers 技术解析:为什么叫「协议缓冲区」
后端
悟空码字26 分钟前
手把手搭建Java微服务:从技术选型到生产部署
java·后端·微服务
leonardee27 分钟前
MySQL----case的用法
java·后端
慧慧吖@37 分钟前
Zustand
开发语言·javascript·ecmascript
8***B38 分钟前
Java自然语言处理
java·开发语言·自然语言处理
赛贝维权申诉1 小时前
30款亚马逊热销儿童玩具,美国外观专利侵权预警!
java·开发语言
骑着bug的coder1 小时前
吃烤鱼时突然悟到的:为什么 Java 线程池的扩容逻辑是“反直觉”的?
后端