【Go语言快速上手(三)】数组, 切片与映射

💓博主CSDN主页:杭电码农-NEO💓

⏩专栏分类:Go语言专栏⏪

🚚代码仓库:NEO的学习日记🚚

🌹关注我🫵带你学习更多Go语言知识
  🔝🔝


在这里插入图片描述

GO快速上手

  • 1. 前言
  • 2. 数组详解
  • 3. 切片详解
  • 4. 映射详解
  • 5. GO语言的错误处理
  • 6. 总结

1. 前言

在了解过GO的控制语句和函数后,按照学习语言的逻辑也理应进入到容器的学习,GO语言的容易比较特殊,它不像C++一样有专门的STL库,类型也没有其他语言那么多.但是都非常的实用!

本章重点:

本篇文章会讲解GO语言中数组的使用,以及GO语言中的切片是什么,映射是什么?它们应该如何使用?最后会讲解GO语言中捕捉错误的方式.文章重在实践,底层原理不涉及


2. 数组详解

如何定义数组:

var arr [3]int
//分别对应 arr->数组名, [3]->数组的大小 int->数组中元素类型
arr[0] = 10
arr[1] = 20
arr[2] = 30

如何遍历数组: 两种方法

var arr [3]int
arr[0] = 10
arr[1] = 20
arr[2] = 30
//普通for循环
for i:=0;i<len(arr);i++{fmt.Println(arr[i])
}
//for - range遍历
for k,v := range arr{fmt.Printf("下标为: %d,值为: %d",k,v)
}

如何初始化数组: 四种方法

//方法一
var arr [3]int{3,6,9}
//方法二
var arr = [3]int{2,4,6}
//方法三,不定长,当初始化为1.3.5.7.9后,长度自动变成5
var arr = [...]int{1,3,5,7,9}
//方法四,指定下标的值,下标2的值为66,下标3的值为77,以此类推
var arr = [...]int{2:66,3:77,1:11,0:55}

二维数组的使用:

//2×3的数组
var arr [2][3]int = [2][3]int{ {1,4,7} , {2,5,8} }
for k,v := range arr{for key,value := range v{fmt.Println(value)}
}

数组的注意事项:

  • 数组不能像C++的vector一样增加/删除元素,更无法扩容.它定义,初始化好后的长度就定了
  • 数组在GO中的使用较少,切片的使用较多(切片是动态增长的)

3. 切片详解

切片是golang的特有类型,它是一种建立在数组类型之上的一种抽象结构, 切片(slice)是对数组的一个连续的片段的引用,所以切片是引用类型.这个引用可以是整个数组,也可以是数组中某个特定的区间

在这里插入图片描述

切片底层有三个字段

  1. 指向底层数组的指针
  2. 切片的长度: length
  3. 切片的容量: capacity

如果你学过vector的底层,会发现和切片是一样的

切片的定义:

1. 通过数组来定义切片

//先定义一个数组
var arr = [6]int{1,2,3,4,5,6}
//定义一个切片,名字是slice,是动态变化的数组
var slice1 []int = arr[1:4]
//切片的索引从1开始到4结束,但不包含下标4,也就是说切片的内容为2.3.4
var slice2 := arr[2:5]

2. 使用make函数定义切片

//make函数的参数分别代表切片对于的类型,切片的长度,切片的容量
slice := make([]int,4,20)
slice[0] = 10
slice[1] = 20
fmt.Println(slice)

在这里插入图片描述

3. 直接定义

slice := []int{2,4,6,8}

切片是可以动态增长的,使用append函数:

slice1 := []int{3,6,9}
//使用append不会影响原来的数组,会创建一份新的空间
slice2 := append(slice1,12,15}//一次性可以追加多个内容,甚至追加多个切片
fmt.Println(slice2)
slice2 := append(slice2,18,21)//可自己追加自己

当你不断的向切片中增加数据直到达到了切片的容量上限后,切片会进行扩容,所以说切片实际上和C++中的vector是类似的,只不过切片没有直接支持删除操作,我们可以通过一些特有的后端来达到删除的效果.一种常用的方法是使用切片的切片操作(slice operation)来删除元素。你可以将要删除的元素之前的元素和之后的元素组合起来,形成一个新的切片,从而达到删除元素的目的。下面是一个示例代码:

func removeElement(slice []int, index int) []int {  return append(slice[:index], slice[index+1:]...)  
}  
func main() {  slice := []int{1, 2, 3, 4, 5}  index := 2  newSlice := removeElement(slice, index)  fmt.Println(newSlice) // 输出: [1 2 4 5]  
}

切片的遍历: 方法和数组是一样的


4. 映射详解

所谓的映射(map),其实就是哈希,只不过GO语言中将map设成了内置的类型,和int,string等是同等地位

在这里插入图片描述

map初始化后是不会分配空间的,所以要使用make来初始化.并且map的key-value是无序的,如果你学过C++的map和unordered_map的话,你就可以明白,GO的map是无序的,所以它底层肯定是用的哈希,而不是红黑树

//定义一个map变量a,它的key-value类型是int-string. 它能存储10对键值对
var a map[int]string = make(map[int]string,10)
a[001] = "张三"
a[002] = "李四"
a[003] = "王五"
var b map[int]string = make(map[int]string)
//若没分配空间,使用时会自动扩容

注意,key是不可重复的,可能出现了重复的key,第一个value会被第二个value替换

在这里插入图片描述

//除此之外,map还可以这样定义
c := map[int]string{2001 : "张三"2002 : "李四"2003 : "王五"
}

map的遍历:

var a map[int]string = make(map[int]string,10)
a[001] = "张三"
a[002] = "李四"
a[003] = "王五"
for k,v := range a{fmt.Printf("key为: %d, value为: %d",k,v)
}

5. GO语言的错误处理

GO语言代码追求优雅简洁,所以它引入了defer+recover的机制来处理错误,如果你不知道defer关键字的作用,请移步这篇文章: go语言函数讲解

在这里插入图片描述

先来个实例看看:

//1. 不使用错误处理
func test(){num1 := 10num2 := 0result := num1/num2fmt.Println(result)
}
func main(){test()
}

此场景中,不进行错误捕捉处理的话,代码执行到num1/num2时,就会报错,程序会直接退出.但是某些时候,这些错误并不致命,还不至于直接让程序退出.所以说需要使用错误捕捉的方式来处理错误

//2. 使用错误处理
//defer+匿名函数,捕捉到错误后还会向后执行代码,不会退出程序
func test(){//利用defer+recover来捕获错误defer func(){//调用recover内置函数,可以捕捉错误err := recover()//如果没有错误,会返回零值,也就是nilif err !=nil{fmt.Println("错误已经捕获,err是: ",err)}}num1 := 10num2 := 0result := num1/num2fmt.Println(result)
}
func main(){test()
}

自定义错误类型:

在这里插入图片描述

func test() (err error){num1 := 10num2 := 0if num2==0{//抛出自定义错误return errors.New("除数不能为0哦~~")}else{//如果除数不为0再正常执行代码result := num1/num2fmt.Println(result)//没有错误,就返回nilreturn nil}
}

6. 总结

GO的用法很简洁,很规范,有句话叫优雅的代码会说话,这也是为什么越来越多的大厂都在转GO的原因.GO语言虽然没有像C++的STL库中那么多数据结构,但GO中有的类型都是最实用的,GO抛弃了繁杂并且琐碎的结构,这一点会在后面的学习中慢慢体现


🔎 下期预告:面向对象三大特性 🔍

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/638348.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深度学习transformer架构详细详解

一、transformer的贡献 transformer架构的贡献&#xff1a;该架构只使用自注意力机制&#xff0c;没有使用RNN或卷积网络。且可以实现并行计算&#xff0c;加快模型训练速度。 &#xff08;将所有的循环层全部换成&#xff1a;multi-headed self-attention&#xff09; 二、t…

【MySQL 数据宝典】【磁盘结构】- 005 Undo log 撤销日志

一、基本介绍 ​ 每当我们要对一条记录做改动时&#xff08;这里的改动可以指 INSERT 、 DELETE 、 UPDATE &#xff09;&#xff0c;都需要留一手 -> 把回滚时所需的东西都给记下来 ​ 你插入一条记录时&#xff0c;至少要把这条记录的主键值记下来&#xff0c;之后回滚的…

5种搭建LLM服务的方法和代码示例

在不断发展的大型语言模型&#xff08;LLMs&#xff09;领域中&#xff0c;用于支持这些模型的工具和技术正以与模型本身一样快的速度进步。在这篇文章中&#xff0c;我们将总结5种搭建开源大语言模型服务的方法&#xff0c;每种都附带详细的操作步骤&#xff0c;以及各自的优缺…

【Python】掌握Python函数:从Hello World到高级技巧

欢迎来到CILMY23的博客 本篇主题为&#xff1a; 掌握Python函数&#xff1a;从Hello World到高级技巧 个人主页&#xff1a;CILMY23-CSDN博客 系列专栏&#xff1a;Python | C | C语言 | 数据结构与算法 感谢观看&#xff0c;支持的可以给个一键三连&#xff0c;点赞关注收…

4个方法教你零基础也能轻松搞定微信恢复!

“刚刚因为不知名原因&#xff0c;微信要重新登录并请好友验证&#xff0c;等登上后以前的信息都不见了。我不求全部&#xff0c;只求恢复与父母的聊天记录&#xff0c;求求各位大佬帮帮忙。” 有时候我们可能会不小心删除了重要的微信聊天记录或者文件&#xff0c;导致数据的丢…

java可盈保险合同管理系统的设计与实现(springboot+mysql源码+文档)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的可盈保险合同管理系统。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 项目简介&#xff1a; 基于Spring Boot的…

MBD_入门篇_20_Simulink子系统

20.Simulink子系统 20.1 概述 Simulink的子系统&#xff0c;相当于代码的function函数&#xff0c;但是模型的子系统又不完全等效于代码的函数。虚拟子系统并不会生成函数&#xff0c;而是以代码块的形式放在相应的调用位置上。模型层面我们使用子系统去做模块化的设计&#xf…

Oracle之SQL plus的一些经验心得

每次登入SQL plus后,不知道时哪个用户登入,非常不方便,只能使用show user查看。 以下时可以通过一些设置实现上述的效果,知道时哪个用户登入,和实现输出效果等 1)SQL plus使用细则 SQL plus登录时,我们可以设置一些通用的设置,在每次登入SQL plus的时候生效。 [root@c…

C++学习————第八天(C/C++内存管理)

目录 1、1.C/C内存分布 2、 C语言中动态内存管理方式&#xff1a;malloc/calloc/realloc/free 3、C内存管理方式 3.1 new/delete操作内置类型 3.2 new和delete操作自定义类型 4.operator new与operator delete函数 5. new和delete的实现原理 5.1 内置类型 5.2 自定…

2022第十三届蓝桥杯省赛C++A组:求和

题目描述 解题思路 对题目进行分析&#xff0c;可知两两相乘再相加的和由下式决定 内层求和可用总和不断减去a[i]来记录 代码 #include<bits/stdc.h> #include<unordered_map> using namespace std; int main() {vector<int> nums;int N;cin >> N;v…

Linux——网络管理nmcli

nmcli 不能独立使用&#xff0c;需要对应的服务启动 1. NetworkManager.service 2. 网络配置和服务不相关 3. 通过 nmcl &#xff49; 建立网络配置和网卡之前的映射关系 网卡 简称&#xff1a;nmcli d DEVICE &#xff1a;物理设备 TYPE: 物理设备类型 ethernet 以太网…

代码学习记录49---单调栈

随想录日记part49 t i m e &#xff1a; time&#xff1a; time&#xff1a; 2024.04.20 主要内容&#xff1a;今天开始要学习单调栈的相关知识了&#xff0c;今天的内容主要涉及&#xff1a;柱状图中最大的矩形 84.柱状图中最大的矩形 Topic184.柱状图中最大的矩形 题目&…