golang中的数组

概念:指同一系列同一类型数据的集合。


声明方法如下:

[32]byte //长度为32的数组

[2*N] struct { x,y int32} //复杂类型的数组

[1000]*float64 //指针数组

[3][5]int //二维数组

[2][2][2]float64 //等同于[2]([2]([2]float64))


获取数组长度:arrLength := len(arr)


遍历数组方法如下:

方法一:

for i:=0; i<len(array); i++ {

fmt.Println("Element",i,"of array is",array[i])

}

方法二:

for i,v := range array {

fmt.Println("Array element[","]=",v)

}


特别注意:

在Golang中数组是一个值类型。如果将数组作为函数的参数类型,则在函数调用时该参数将发生数据复制。因此,在函数体中无法修改传入的数组的内容,因为函数内操作的只是所传入数组的一个副本。

packagemain

import"fmt"

funcmodify(array[5]int){
	array[0]=10//trytomodifythefirstelementofarray
	fmt.Println("Inmodify(),arrayvalues:",array)
}

funcmain(){
	array:=[5]int{1,2,3,4,5}//defineandinitanarray
	modify(array)//sendtoafunction,andtrytomodifythecontentofthisarray
	fmt.Println("Inmain(),array)
}

执行结果:

In modify(),array values: [10 2 3 4 5]

In main(),array values: [1 2 3 4 5]

从执行结果可以看出,函数modify()内操作的那个数组跟main()中传入的数组是两个不同的实例。

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...