当前位置: 首页 > article >正文

1.5 Go切片使用

一、切片简介

切片是相同类型元素的可变长度的集合,通常表示[]type。同一个切片中的元素类型都是一个类型的。它看上去跟数组一样,但是没有长度

二、切片的组成

每一个切片由三个部分组成

  • 底层数组的指针:指向切片实际存储数据的底层数组的某个位置,切片只是对底层数组的一个视图,不直接包含数据。
  • 长度(len):切片中当前包含的元素个数,也就是切片的有效部分的大小。
  • 容量(cap):切片从当前第一个元素到底层数组的末尾可以容纳的最大元素个数,它决定了切片在扩展时是否需要分配新的底层数组。

三、创建切片

1、基于数组创建切片

package main

import "fmt"

var sl1 = [6]string{"北京", "上海", "深圳", "广州", "杭州", "重庆"}

func main() {
	// sl1 = [5]string{"北京", "上海", "深圳", "广州", "杭州"}
	fmt.Println(sl1[5])
}

2、直接创建

package main

import "fmt"

var sl1 = []string{"北京", "上海", "深圳", "广州", "杭州", "重庆"} //直接创建切片
func main() {
	fmt.Println(sl1[5])
}

3、使用内建make函数创建切片

package main

import "fmt"

func main() {
	// 创建一个长度为 6,容量为 6 的切片
	city1 := make([]string, 6)  // city1 的长度是 6,容量是 6
	fmt.Println("city1:", city1) // city1: ["" "" "" "" "" ""]
	fmt.Println("len(city1):", len(city1))  // 6
	fmt.Println("cap(city1):", cap(city1))  // 6

	// 创建一个长度为 6,容量为 8 的切片
	city2 := make([]string, 6, 8)  // city2 的长度是 6,容量是 8
	fmt.Println("city2:", city2) // city2: ["" "" "" "" "" ""]
	fmt.Println("len(city2):", len(city2))  // 6
	fmt.Println("cap(city2):", cap(city2))  // 8
}

四、切片长度和容量

package main

import "fmt"

var sl1 = []string{"北京", "上海", "深圳", "广州", "杭州", "重庆"} // 直接创建一个切片

func main() {
	// city3 := sl1[1:4] // 创建一个从 sl1 切片中提取的子切片
	fmt.Println(city3) // 打印 city3
	fmt.Println(len(city3)) // 打印 city3 的长度
	fmt.Println(cap(city3)) // 打印 city3 的容量
}

切片类型的默认初始化值是 nil,此时切片没有关联任何底层数组,且其长度和容量均为 0。因此,切片只能与 nil 进行比较。如果需要检查切片是否为空,可以通过 len() == 0 来判断。

sl1 切片的初始化:sl1 是一个包含 6 个元素的切片,具体内容是:"北京", "上海", "深圳", "广州", "杭州", "重庆"。

切片操作:sl1[1:4]

从 sl1 切片中获取一个新的子切片 city3。切片操作的语法是 sl1[start:end],表示取 sl1 中从 start 索引到 end-1 索引的元素。注意这里的 end 是不包括的,所以实际上取的是 sl1[1] 到 sl1[3] 的元素

city3 := []string{"上海", "深圳", "广州"}

len() 和 cap()解释

  • len(city3):len() 返回的是切片中元素的数量,也就是切片的长度。由于 city3 包含 "上海", "深圳", "广州" 三个元素,len(city3) 返回的是 3。
  • cap(city3):cap() 返回的是切片的容量,即切片在不重新分配底层数组的情况下能够容纳的最大元素个数。对于 city3 来说,它是从 sl1[1:4] 提取的,因此底层数组仍然是 sl1 所引用的那个数组。所以 city3 的容量是从 sl1[1] 到 sl1 的末尾(即 sl1[5])的长度,这个长度是 5。也就是说,虽然 city3 的长度是 3,但是它可以继续扩展到 sl1 的末尾,总共可以容纳 5 个元素。因此,cap(city3) 返回的是 5。

打印结果

[上海 深圳 广州]

长度是4减去1==3,容量是多少?

容量解释:

  • city3 的长度 (len(city3)) 是 3,因为它包含了 3 个元素:“上海”, “深圳”, “广州”。
  • city3 的容量 (cap(city3)) 是 5,因为它是从 sl1[1:4] 切割出来的,而 sl1 的长度是 6,所以 city3 还有 3 个元素的扩展空间(从 sl1[4] 到 sl1[5])。

总结要点

  • 切片的 长度 是当前切片所包含的元素数量。
  • 切片的 容量 是切片在不重新分配底层数组的情况下可以容纳的最大元素数量。
  • 如果切片是从另一个切片中切割出来的,那么它的底层数组与原切片共享,因此它的容量会基于原切片的容量来决定。


http://www.kler.cn/a/531330.html

相关文章:

  • 技术架构师成长路线(2025版)
  • Rust中使用ORM框架diesel报错问题
  • 电控三周速成计划参考
  • PHP实现混合加密方式,提高加密的安全性(代码解密)
  • 强化学习、深度学习、深度强化学习的区别是什么?
  • FFmpeg(7.1版本)在Ubuntu18.04上的编译
  • 浅谈量化感知训练(QAT)
  • 机器学习--学习计划
  • Intel 与 Yocto 项目的深度融合:全面解析与平台对比
  • 变形金刚多元宇宙
  • 【汽车电子软件架构】AutoSAR从放弃到入门专栏导读
  • 【探索篇】探索部署离线AI在Android的实际体验
  • ChatGPT提问技巧:行业热门应用提示词案例--办公应用
  • SpringAI 人工智能
  • Pandas基础08(分箱操作/时间序列/画图)
  • [SAP ABAP] 性能优化
  • 解决注入线程池的栈溢出问题
  • [LeetCode] 字符串完整版 — 双指针法 | KMP
  • 【Python】容器
  • 双目标定与生成深度图
  • AP单类平均准确率
  • MySQL 插入数据指南
  • 一文读懂 RAG:LLM 借助检索打开思路
  • 响应式编程与协程
  • Hot100之图论
  • 02 使用 海康SDK 对人脸识别设备读取事件