编程笔记 Golang基础 023 切片

2024-02-24 00:04

本文主要是介绍编程笔记 Golang基础 023 切片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编程笔记 Golang基础 023 切片

  • 一、切片
  • 二、定义与初始化
  • 三、基本操作
  • 四、示例

Go语言中的切片(slices)是基于数组的抽象数据类型,它提供了一种灵活的方式来处理可变长度的数据序列。切片本身不存储任何数据,而是指向底层数组的一个连续区域,并记录了该区域的长度和容量。

一、切片

Go语言中的切片(slices)是基于数组的抽象数据类型,它提供了一种灵活的方式来处理可变长度的数据序列。切片本身不存储任何数据,而是指向底层数组的一个连续区域,并记录了该区域的长度和容量。
切片(slices)在Go语言中主要用于管理动态大小的、连续内存区域中的元素序列。它们是数组概念的一种抽象,提供了对底层数组的一个可变视图,允许程序员更加灵活地操作数据集合。切片的主要用途包括:

  1. 动态扩展:与固定长度的数组不同,切片的长度可以增长或缩短,这意味着开发者可以在程序运行时根据需要添加或删除元素。

  2. 高效访问和修改:虽然切片是引用类型,但其内部仍然是基于连续内存的数组,因此它继承了数组快速随机访问的优点,对于大量数据的操作非常高效。

  3. 内存管理简化:切片自动处理内存分配和可能的扩容需求,通过 append 函数可以很容易地在末尾追加元素,如果容量不足,Go会自动创建一个新的更大的数组,并将原数组的数据复制过去。

  4. 子集操作:可以通过索引范围来创建一个原始切片的新视图(即子切片),而不需要复制任何数据。这样可以方便地处理大型数据结构的一部分。

  5. 函数参数和返回值:由于切片具有轻量级的特点(仅存储指向数组的指针、长度和容量),将其作为函数参数传递比传递整个数组更高效,同时,它可以作为多变数量参数或动态生成结果的理想选择。

综上所述,Go语言中的切片适用于大多数需要动态、灵活处理一系列相同类型数据的情况,例如实现堆栈、队列、列表等数据结构,或者在文本处理、网络编程等领域中处理不定长度的数据流。

二、定义与初始化

// 通过 make 函数创建一个长度为3、容量也为3的整数切片
slice := make([]int, 3)
// 或者直接初始化
slice2 := []int{1, 2, 3}// 创建并初始化的同时指定容量(长度必须小于等于容量)
slice3 := make([]int, 2, 5) // 长度为2,容量为5

三、基本操作

  • 访问元素与修改元素:
slice := []int{10, 20, 30}
fmt.Println(slice[0]) // 输出: 10
slice[1] = 30 // 修改第二个元素为30
  • 遍历切片:
for index, value := range slice {fmt.Printf("Index: %d, Value: %d\n", index, value)
}
  • 切片截取(子切片):
// 创建一个新的切片,引用原切片的部分元素
subSlice := slice[1:3]
fmt.Println(subSlice) // 输出: [20 30]
  • 扩展切片:
// 使用 append 函数添加元素到切片,如果超出容量会自动扩容
slice = append(slice, 40)
fmt.Println(slice) // 输出: [10 30 30 40]

四、示例

package mainimport ("fmt"
)func main() {// 初始化一个切片slice := []int{1, 2, 3, 4, 5}// 打印原始切片fmt.Println("Original Slice:", slice)// 截取子切片subSlice := slice[1:3]fmt.Println("Sub-slice:", subSlice)// 在原始切片上追加元素slice = append(slice, 6, 7, 8)fmt.Println("Appended Slice:", slice)// 遍历切片for i, v := range slice {fmt.Printf("Index: %d, Value: %d\n", i, v)}// 容量和长度查询lenOfSlice := len(slice)capOfSlice := cap(slice)fmt.Printf("Length of slice: %d, Capacity of slice: %d\n", lenOfSlice, capOfSlice)// 创建新的切片,但共享相同的底层数组空间newSlice := slice[:lenOfSlice/2]fmt.Println("New Slice (shares memory):", newSlice)// 修改新切片影响原始切片newSlice[0] = 99fmt.Println("After modification to newSlice:")fmt.Println("Original Slice:", slice)fmt.Println("New Slice:", newSlice)
}

在这个综合示例中,我们展示了如何初始化切片、截取子切片、扩展切片、遍历切片以及查看切片的长度和容量。同时,还展示了切片之间的内存关系:对一个切片的修改可能会影响到共享相同底层数组的其他切片。

这篇关于编程笔记 Golang基础 023 切片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/740357

相关文章

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

深入理解RxJava:响应式编程的现代方式

在当今的软件开发世界中,异步编程和事件驱动的架构变得越来越重要。RxJava,作为响应式编程(Reactive Programming)的一个流行库,为Java和Android开发者提供了一种强大的方式来处理异步任务和事件流。本文将深入探讨RxJava的核心概念、优势以及如何在实际项目中应用它。 文章目录 💯 什么是RxJava?💯 响应式编程的优势💯 RxJava的核心概念