当前位置: 首页 > 编程笔记 >

理解Golang中的数组(array)、切片(slice)和map

锺离德运
2023-03-14
本文向大家介绍理解Golang中的数组(array)、切片(slice)和map,包括了理解Golang中的数组(array)、切片(slice)和map的使用技巧和注意事项,需要的朋友参考一下

我比较喜欢先给出代码,然后得出结论

数组


package main

import (     "fmt" )

func main() {     arr := [...]int{1, 2, 3}     //打印初始的指针     fmt.Printf("the pointer is : %p \n", &arr)     printPointer(arr) }

func printPointer(any interface{}) {     fmt.Printf("the pointer is : %p \n", &any) }

结果


1 the pointer is : 0xc082008580 

2 the pointer is : 0xc0820001d0 

切片


package main

import (     "fmt" )

func main() {     arr := make([]int, 3)     //打印初始的指针     fmt.Printf("the pointer is : %p \n", arr)     printPointer(arr) }

func printPointer(any interface{}) {     fmt.Printf("the pointer is : %p \n", any) }

结果


1 the pointer is : 0xc082008580 

2 the pointer is : 0xc082008580 

map


package main

import (     "fmt" )

func main() {     arr := make(map[int]string)     //arr := [3]int{1, 2, 3}     //打印初始的指针     fmt.Printf("the pointer is : %p \n", arr)     printPointer(arr) }

func printPointer(any interface{}) {     fmt.Printf("the pointer is : %p \n", any) }

运行结果


1 the pointer is : 0xc082007c80 

2 the pointer is : 0xc082007c80 

由此,我们看到数组本身传过去的是值,传到函数之后,被开辟了另外一个空间。

因为数组就是他本身。这一句好像不太好理解。

这是切片 arr := make([]int, 3)  而arr 本身不是一个数组,至少不是我们所想要的指向的一个数组。只是arr里有一个地址指向数组。

这么举个例子:

arr := [...]int{1,2,3,4,5} 这是一个数组,懂得go语言的都明白。  arr本身就是数组

arrSlice := arr[0:5]  这是一个切片。 打印所得的值是一样的,和上面。  arrSlice本身不是数组,只是arrSlice本身有一个值是指向arr的指针。

切片是指一个结构体,大体结构像这样:


struct slice{

     ptr *Elem

    len int

    cap int

 }

也就是说,上面的arrSlice其实是一个结构体。里面有一个属性 ptr指向数组 arr

其实arrSlice也是传到函数里,也是进行了复制。但是尽管传过去是一个复制的结构体,他的属性ptr,没有变。还是一个指向原数组的指针。

下面的例子见证他自己传过去,是一个复制的过程:


package main

import (     "fmt" )

func main() {     arrSlice := make([]int, 4)     fmt.Printf("the pointer is : %p \n", arrSlice)     fmt.Printf("the pointer is : %p \n", &arrSlice) //这是arrSlice本身的指针,也就是结构体的指针     printPointer(arrSlice) }

func printPointer(any interface{}) {     fmt.Printf("the pointer is : %p \n", any)     fmt.Printf("the pointer is : %p \n", &any) //打印传过来的结构体arrSlice的指针 }

看结果:


the pointer is : 0xc0820085a0 

the pointer is : 0xc082008580 

the pointer is : 0xc0820085a0 

the pointer is : 0xc0820001d0 

第1、3个的打印是打印这个结构体的ptr属性,也就是指向数组的指针。

其实这个结构体传到函数里,是一个复制的过程,第2、4的指针不一样。

大家在对照下面的图片理解一下:

 类似资料:
  • 本文向大家介绍浅谈golang slice 切片原理,包括了浅谈golang slice 切片原理的使用技巧和注意事项,需要的朋友参考一下 slice介绍 数组的长度在定义之后无法再次修改;数组是值类型,每次传递都将产生一份副本。显然这种数据结构无法完全满足开发者的真实需求。在初始定义数组时,我们并不知道需要多大的数组,因此我们就需要“动态数组”。在Go里面这种数据结构叫slice,slice并不

  • 本文向大家介绍golang常用手册之切片(Slice)原理,包括了golang常用手册之切片(Slice)原理的使用技巧和注意事项,需要的朋友参考一下 切片,这是一个在go语言中引入的新的理念。它有一些特征如下: 对数组抽象 数组长度不固定 可追加元素 切片容量可增大 容量大小成片增加 我们先把上面的理念整理在这里,但是实际的还是要撸码来解决问题。 定义或申明切片 首先我们看看申明切片: 定义完成

  • 得出的结果是: [0 0] [0 0 6 6 6] [0 0] [0 0 6 6 6 0 0 0 0 0] 请问一下,第三个结果为什么是[0 0],而不是 [0 0 6 6 6] 呢, 在Test2 函数中,使用append的时候,并没有扩容,添加的数据还在底层数组的容量中, 那为啥在 Test2函数之后 s3是[0 0] 即使是在原有的容量基础上扩容,那为啥 s4:=s3[0:10] 是[0 0

  • Slice切片   Go中的数组和PHP中的数组很不一样,没法排序,没法添加。不过Go中有一种数据类型叫做Slice切片,这个数据类型很类似于PHP中的数组。我个人感觉也是利用率比较高的数据类型。   Slice切片实际上是对一个数组上的连续一段的引用,一个未初始化的分片的值是nil。一个切片,一旦初始化后它总是关联着一个容纳其元素的底层数组,所以一个分片和它的数组共享存储。 定义 slice :

  • 概述 切片是一种动态数组,比数组操作灵活,长度不是固定的,可以进行追加和删除。 len() 和 cap() 返回结果可相同和不同。 声明切片 //demo_7.go package main import ( "fmt" ) func main() { var sli_1 [] int //nil 切片 fmt.Printf("len=%d cap=%d sl

  • 本文向大家介绍Golang slice切片操作之切片的追加、删除、插入等,包括了Golang slice切片操作之切片的追加、删除、插入等的使用技巧和注意事项,需要的朋友参考一下 本文介绍了Golang slice切片操作之切片的追加、删除、插入等,分享给大家,具体如下: 一、一般操作 1,声明变量,go自动初始化为nil,长度:0,地址:0,nil 2,切片的追加,删除,插入操作 3,copy的