Go语言中的数组(九)
我刚接触go语言的数组时,有点不习惯,因为相对于JavaScript这样的动态语言里的数组,go语言的数组写起来有点不爽。
定义数组
go语言定义数组的格式如下:
var a []int var 数组名 [数组长度]数组每一项的类型
初始化数组时,要定义好数组的长度和数组值的类型。注意定义数组时,数组的长度数字应该是常量,如果使用变量来定义长度则会报错:
var l =
var a [l]int // 此时长度使用变量 l 来定义,会报错
同时,不同的数组长度和类型,导致最终的数组也是不同的类型:
var a []int
var b []int // a 和 b 是不同的类型
数组赋值时是用 {},这点也是我最不习惯的地方:
func main() {
var a []int
a = []int{,,}
fmt.Println(a) // [1 2 3]
}
注意打印的结果是中括号的,但是没有用 , 来隔开每一项。
上面是先定义再赋值的,有点繁琐,可以一步到位地简写:
func main() {
a := []int{,,}
fmt.Println(a)
}
有时,我们一开始不知道数组的长度应该是多少,此时可以这样定义数组:
func main() {
a := [...]int{1,2,3}
fmt.Println(a)
}
// 用 ... 来表示未知的数组长度
同时,我们在初始化数组时也可以指定对应下标的值:
func main() {
a := [...]int{:,:}
fmt.Println(a) // [0 0 10 0 0 12]
}
代码中在定义数组时,指定下标2位置上的值是10,下标5位置上的值是12,其余未指定值的默认为0
遍历数组
使用for 循环来遍历数组:
func main() {
a := [...]int{,,,,}
for i:=;i<;i++{
fmt.Println(a[i])
}
}
// a[i] 是数组取值,格式:数组名[下标]
也可以使用 range 来遍历:
func main() {
a := [...]int{,,,,}
for _,v := range a{
fmt.Println(v)
}
}
// _ 是占位,此位置本来是下标,此处不用下标所以用 _ 占位
二维数组
二维数组的定义如下:
func main() {
a:=[][]int{
[]int{,},
[]int{,},
[]int{,},
}
fmt.Println(a) // [[1 2] [3 4] [5 6]]
}
可以看到这样是比较繁琐的,其实可以简化为:
func main() {
a:=[][]int{
{,},
{,},
{,},
}
fmt.Println(a) // [[1 2] [3 4] [5 6]]
}
如果你细心你会发现,我在最后一项后面加上了逗号,这是因为go语言的格式限制,这样收起花括号就不用加逗号了:
func main() {
a:=[][]int{
{,},
{,},
{,}}
fmt.Println(a)
}
数组是值类型
没错,在go中数组是值类型,这与我之前接触到的一些动态语言可完全不一样。关于值类型和引用类型,我就不多说了。直接来看下例子吧:
package main
import "fmt"
func main() {
var a = []int{,,}
var b = a
a[] =
fmt.Printf("a:%v,b:%v",a,b) // a:[4 2 3],b:[1 2 3]
}
Go语言中的数组(九)的更多相关文章
- go语言中的数组切片:特立独行的可变数组
go语言中的数组切片:特立独行的可变数组 初看go语言中的slice,觉得是可变数组的一种很不错的实现,直接在语言语法的层面支持,操作方面比起java中的ArrayList方便了许多.但是在使用了一段 ...
- Go 语言中的数组是一种 值类型(不像 C/C++ 中是指向首元素的指针)
the-way-to-go_ZH_CN/07.1.md at master · Unknwon/the-way-to-go_ZH_CN https://github.com/Unknwon/the-w ...
- Go语言中底层数组和切片的关系以及数组扩容规则
Go语言中底层数组和切片的关系以及数组扩容规则 demo package main import ( "fmt" ) func main() { // 声明一个底层数组,长度为10 ...
- C语言中动态分配数组
如何动态的定义及使用数组呢?记得一般用数组的时候都是先指定大小的.当时问老师,老师说是不可以的.后来又问了一位教C++的老师,他告诉我在C++里用new可以做到,一直不用C++,所以也不明白.今天在逛 ...
- C语言中的数组和指针以及字符串
数组名同时也是该数组首元素的地址,而指针提供了一种用来使用地址的符号方法,因此指针能够很有效地处理数组. 将一个整数加给指针,这个整数会和指针所指类型的字节数相乘,然后所得的结果会加到初始地址上 da ...
- 【转】C语言中动态分配数组
原文地址:http://blog.chinaunix.net/uid-11085590-id-2914577.html 如何动态的定义及使用数组呢?记得一般用数组的时候都是先指定大小的.当时问老师,老 ...
- c语言中字符串数组初始化的一点总结&& c++访问控制的三种方式
char *c[]={"ONE","TWO","THREE","FOUR"}; // c语言中定义了一个字符串数组(也称 ...
- C语言中的数组与字符串
1. 数组与指针: 对于数组,需要注意两点:1, C语言中只有一维数组, 而且数组的大小必须在编译期就作为一个常数确定下来: 2. 对于一个数组,我们只能做两件事:确定数组的大小 和 获得指向该数组下 ...
- C语言中的数组的使用——混乱的内存管理
在C语言中想要创建数组只能自己malloc或者calloc,数组复制则是memcpy. 这样创建出来的数组在调用时是不会检测数组边界的,即你声明了一个长度为5的数组,却可以访问第6个位置……也可以给第 ...
随机推荐
- Harmonic Number (LightOJ 1234)(调和级数 或者 区块储存答案)
题解:隔一段数字存一个答案,在查询时,只要找到距离n最近而且小于n的存答案值,再把剩余的暴力跑一遍就可以. #include <bits/stdc++.h> using namespace ...
- Navicat Premium12远程连接MySQL数据库
https://blog.csdn.net/dengjin20104042056/article/details/95091506 方法二: step1: 修改表user mysql> use ...
- Android_(自动化)自动获取手机电池的剩余电量
自动获取手机电池的剩余电量 通过使用BroadcastReceiver的特性来获取手机电池的电量,注册BroadcastReceiver时设置的IntentFilter来获取系统发出的Intent.A ...
- Gitlab启动、停止、重启(两种启动方式)
因为Gitlab不是我部署的,是之前总监部署的,服务器突然更新系统了,Git服务器就没有自启··自启··自启······,自己操作启动没有成功,然后网上搜了一下都是这三种启动关闭重启的方式,可是我这里 ...
- Java线程中的异常处理
对于对线程,当主线程中有子线程运行出现异常时,主线程是不能捕获到该异常的,子线程会直接退出,不会记录任何日志. 解决: 1.子线程中try catch. 2.设置线程的未捕获异常处理器,Uncaugh ...
- 「Luogu P5601」小D与笔试
题目链接 戳我 \(Solution\) 这道题官方题解的做法太复杂了,还需要扫字符串. 其实只需要两个\(map\)就好了. 一个\(map<string,stirng>\)用来记录题目 ...
- JS基础_toString()
当我们直接在页面中打印一个对象时,实际上是输出的对象的toString()方法的返回值 如果我们希望在输出对象时不输出[ object Object ],可以为对象添加一个toString()方法或者 ...
- 打开下载CA root 证书的链接失败
下载CA root 证书 http://adip/certsrv server error or refuse to connect 这是由于AD上没有安装Active Directory Certi ...
- 【好书推荐】9、安卓Andorid编程吐血整理100+本
点开即可
- Python:目录
ylbtech-Python:目录 1.返回顶部 2.返回顶部 3.返回顶部 4.返回顶部 5.返回顶部 6.返回顶部 作者:ylbtech出处:http://ylbtec ...