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个位置……也可以给第 ...
随机推荐
- SDOI2015 寻宝游戏 | noi.ac#460 tree
题目链接:戳我 可以知道,我们相当于是把有宝藏在的地方围了一个圈,求这个圈最小是多大. 显然按照dfs序来遍历是最小的. 那么我们就先来一遍dfs序列,并且预处理出来每个点到根的距离(这样我们就可用\ ...
- Linux 打印可变参数日志
实现了传输进去的字符串所在的文档,函数和行数显示功能. 实现了将传入的可变参数打印到日志功能. #include<stdio.h> #include<stdarg.h> #in ...
- IT公司技术博客地址
IT公司技术博客 美团点评技术团队今日头条技术博客Tencent ISUX DesignTGideas-腾讯互动娱乐创意设计团队>AlloyTeam | 腾讯全端 AlloyTeam 团队 Bl ...
- 修改jupyter notebook的字体等样式
方法一 /lib/site-packages/notebook/static/custom/ 里面有个custom.css文件,你只要修改这个文件就可以了. /* jupyter notebook中显 ...
- State Threads之Co-routine的调度
1. 相关结构体 1.1 _st_epoll_data static struct _st_epolldata { _epoll_fd_data_t *fd_data; /* 调用 epoll_wai ...
- SUSE zypper 本地源配置
存放repo 文件目录 cd /etc/zypp/repos.d 创建用来存放ISO文件的目录: mkdir /opt/iso 将服务器端的存放ISO文件的目录挂载到本机: mount -t cifs ...
- weblogic性能调优
1.设置java参数: a) 编辑Weblogic Server启动脚本文件: /user_projects/domains/Domain_jgbs/bin/startWebLogic.sh /use ...
- jquery 复合事件 toggle()方法的使用
定义和用法 toggle() 方法用于绑定两个或多个事件处理器函数,以响应被选元素的轮流的 click 事件. 语法: $(selector).toggle(function1(),function2 ...
- spring boot知识清单
https://mp.weixin.qq.com/s/q8OI2Ou8-gYP-usjToBbkQ
- python pymysql 连接 mysql数据库进行操作
1.数据库的连接操作 import pymysql conn = pymysql.connect(host=', db='oldboydb') # host表示ip地址,user表示用户名,passw ...