Go - 数组

概述

数组是一个由固定长度的特定类型元素组成的序列,一个数组可以由零个或多个元素组成,一旦声明了,数组的长度就固定了,不能动态变化。

len()cap() 返回结果始终一样。

声明数组

package main
import (
 "fmt"
)
func main() {
 //一维数组
 var arr_1 [5] int
    fmt.Println(arr_1)
 var arr_2 = [5] int {1, 2, 3, 4, 5}
    fmt.Println(arr_2)
    arr_3 := [5] int {1, 2, 3, 4, 5}
    fmt.Println(arr_3)
    arr_4 := [...] int {1, 2, 3, 4, 5, 6}
    fmt.Println(arr_4)
    arr_5 := [5] int {0:3, 1:5, 4:6}
    fmt.Println(arr_5)
 //二维数组
 var arr_6 = [3][5] int {{1, 2, 3, 4, 5}, {9, 8, 7, 6, 5}, {3, 4, 5, 6, 7}}
    fmt.Println(arr_6)
    arr_7 := [3][5] int {{1, 2, 3, 4, 5}, {9, 8, 7, 6, 5}, {3, 4, 5, 6, 7}}
    fmt.Println(arr_7)
    arr_8 := [...][5] int {{1, 2, 3, 4, 5}, {9, 8, 7, 6, 5}, {0:3, 1:5, 4:6}}
    fmt.Println(arr_8)
}

运行结果:

注意事项

一、数组不可动态变化问题,一旦声明了,其长度就是固定的。

var arr_1 = [5] int {1, 2, 3, 4, 5}
arr_1[5] = 6
fmt.Println(arr_1)

运行会报错:invalid array index 5 (out of bounds for 5-element array)

二、数组是值类型问题,在函数中传递的时候是传递的值,如果传递数组很大,这对内存是很大开销。

//demo_5.go
package main
import (
 "fmt"
)
func main() {
 var arr = [5] int {1, 2, 3, 4, 5}
    modifyArr(arr)
    fmt.Println(arr)
}
func modifyArr(a [5] int) {
    a[1] = 20
}

运行结果:

//demo_6.go
package main
import (
 "fmt"
)
func main() {
 var arr = [5] int {1, 2, 3, 4, 5}
    modifyArr(&arr)
    fmt.Println(arr)
}
func modifyArr(a *[5] int) {
    a[1] = 20
}

运行结果:

三、数组赋值问题,同样类型的数组(长度一样且每个元素类型也一样)才可以相互赋值,反之不可以。

var arr = [5] int {1, 2, 3, 4, 5}
var arr_1 [5] int = arr
var arr_2 [6] int = arr

运行会报错:cannot use arr (type [5]int) as type [6]int in assignment

推荐阅读

本文欢迎转发,转发请注明作者和出处,谢谢!

本文分享自微信公众号 - 新亮笔记(XinLiangTalk),作者:訢亮

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2019-06-26

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 《二》Swoole Task 的应用

    Swoole 的实现方式是 worker 进程处理数据请求,分配给 task 进程执行。

    新亮
  • 《五》Swoole 多协议 多端口 的应用

    Swoole 支持了2种类型的自定义网络通信协议 :EOF结束符协议、固定包头+包体协议。

    新亮
  • 《四》Swoole HTTP 的应用

    我们都知道 HTTP 是一种协议,允许 WEB 服务器和浏览器通过互联网进行发送和接受数据。

    新亮
  • 2 :基本语法

    六月的雨
  • JavaScript实现冒泡排序

    对数组进行 冒泡排序 算是比较简单的,冒泡排序也是容易理解的一种排序算法了,在面试的时候,很可能就会问到。

    FEWY
  • js排序算法

    山河木马
  • 野生前端的数据结构练习(9)冒泡排序,选择排序,插入排序

    bubble sort的是最基本的算法,被誉为永远会被考从来不被用的算法,基本原则是大数右移,每轮遍历后最右侧的数是最大的,所以下一轮循环时可不予考虑,时间复杂...

    大史不说话
  • LeetCode 1442. 形成两个异或相等数组的三元组数目(前缀异或)

    现需要从数组中取三个下标 i、j 和 k ,其中 (0 <= i < j <= k < arr.length) 。

    Michael阿明
  • js实现数组去重操作

    js数组去重一般两种方法,一种是通过循环判断的方式来去重,另一种方式是通过ES6标准的set集合来实现去重,下面分别来看代码。

    无邪Z
  • 算法之数组和问题

    算法题之数组和求解 数组和问题 ​ 加上给定一个数组和值x。设计一个算法使得如果数组中存在两个元素的和为x,则输出两个元素的值组成的数组(不区分先后),否则输出...

    SecondWorld

扫码关注云+社区

领取腾讯云代金券