目录

  • 数组定义
  • 二维数组
  • 数组拷贝、传参

数组定义

1. 数组是同一类型的元素集合。

var a [3]int
//定义一个数组 //Go中数组下标从0开始,因此⻓长度为n的数组下标范围:[0,n-1] //整数组中的元素默认初始化为0,字符串串数组中的元素默认初始化为””

  

2. 数组初始化

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
//数组初始化 var a [3]int = [3]int{10, 20, 30}
//定义时数组初始化 a := [3]int{10, 20, 30}
//定义时数组初始化 a := […]int{10, 20, 30}
//定义时数组初始化 a := [3]int{10}
//定义时数组初始化 a := [3]int{2:10}
//定义时数组初始化

  

3. 数组⻓长度是类型的一部分

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
var b [5]int
b = a
//a、b是不同类型的数组,不能赋值

  

4、len内置函数

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
fmt.Printf(“len:%d\n”, len(a))
//a、b是不同类型的数组,不能赋值

  

5. 数组遍历

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
for i := 0; i < len(a); i++ {
}
//a、b是不同类型的数组,不能赋值

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
for index, val := range a {
}
//a、b是不不同类型的数组,不不能赋值

二维数组

1、 二维数组

var a [3][2]int
a[0][0] = 10
a[0][1] = 20
a[1][0] = 30
a[1][1] = 30
a[2][0] = 30
a[2][1] = 30
for index, val := range a {
}
//a、b是不不同类型的数组,不不能赋值

  

2、二维数组(二)

// 数组遍历写法二
func testArra10() {
// 数组 a [长度]类型
// 定义完成, 值为[0,0,0,100,300],指定特定下标
a := [5]int{3: 100, 4: 300}
for index, value := range a {
fmt.Printf("a[%d]=%d\n", index, value)
}
}

  

3、二维数组(三)

// 二维数组定义
func testArra11() {
var a [3][2]int
a[0][0] = 10
a[0][1] = 20
a[1][0] = 30
a[1][1] = 40
a[2][0] = 50
a[2][1] = 60 fmt.Println(a) // 遍历二维数组
for i := 0; i < 3; i++ {
for j := 0; j < 2; j++ {
fmt.Printf("%d", a[i][j])
}
fmt.Println()
} //遍历方式二
fmt.Println("other method")
for i, val := range a {
// %v自动匹配格式输出,行
fmt.Printf("row[%d]=%v\n", i, val)
for j, val2 := range val {
fmt.Printf("(%d,%d)=%d", i, j, val2)
}
} }

  

数组拷贝、传参

1、数组是值类型

var a [3]int
a[0] = 10
a[1] = 20
a[2] = 30
b := a
//b拷贝了了数组a中所有元素
b[0] = 1000
fmt.Println(a, b)

  

2、 数组是值类型,函数传参也会拷贝

// 值类型,copy为全拷贝,改变b不会影响a
func testArra12() {
a := [3]int{10, 20, 30}
b := a
b[0] = 1000
fmt.Printf("a=%v\n", a)
fmt.Printf("b=%v\n", b)
} // int类型都是值类型,copy为全拷贝,改变b不会影响a
func testArray13() {
var a int = 1000
b := a
b = 3000
fmt.Printf("a=%d b=%d\n", a, b)
} // 数组传参为copy
func modify(b [3]int) {
b[0] = 1000
}

  

例子:

package main

import (
"fmt"
"math/rand"
"time"
) func sumArray(a [10]int) int {
var sum int = 0
//第一种遍历
for i := 0; i < len(a); i++ {
sum = sum + a[i]
} //第二种遍历, _ 屏蔽下标
//for _, val := range a{
// sum = sum + val
//} return sum
} // 随机10数相加
func testArraySum() { //初始化随机种子,time.Now().Unix()纳秒时间
rand.Seed(time.Now().Unix()) var b [10]int
for i := 0; i < len(b); i++ {
//b[i] = i
//随机 rand
// 产生一个0到999的随机数
b[i] = rand.Intn(1000)
// 产生一个0到Int最大值的随机数
// b[i] = rand.Int()
} sum := sumArray(b)
fmt.Printf("sum=%d\n", sum)
} // 两个元素之和,等于8 target的下标
func TwoSum(a [5]int, target int) {
for i := 0; i < len(a); i++ {
other := target - a[i]
for j := i + 1; j < len(a); j++ {
if a[j] == other {
fmt.Printf("(%d, %d)\n", i, j)
}
}
}
} //
func testTwoSum() {
// var b [5]int = [5]int{1,3,5,8,7}
// b := [5]int{1,3,5,8,7}
b := [...]int{1, 3, 5, 8, 7}
TwoSum(b, 8)
} func main() {
//sumArray()
//testArraySum()
testTwoSum()
}

  

【原创】go语言学习(七)数组的更多相关文章

  1. C语言学习004:数组与指针

    在C语言中,字符串实际上就是字符数组,在内存中字符串"Shatner"存储的形式是这样的

  2. C语言学习笔记--数组指针和指针数组

    C 语言中的数组有自己特定的类型,数组的类型由元素类型和数组大小共同决定.(如 int array[5]类型为 int[5]) 1.定义数组类型 C 语言中通过 typedef 为数组类型重命名:ty ...

  3. go语言学习--指针数组和数组指针

    数组指针(也称行指针)定义 int (*p)[n];()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长.也就是说执行p+1时,p要跨过n个整型数据的 ...

  4. go语言学习(一):数组/切片

    学习区块链之后,发现还要学习加密,接触到的视频是:Go的crypto包,所以开始接触Go.因为和solidity有些相似,但是比solidity简单一些,就开始放松的心态去学习.每天翻着go菜鸟教程, ...

  5. C语言学习笔记--数组参数和指针参数

    1. 数组参数退化为指针的意义 (1)C 语言中只会以值拷贝的方式传递参数,当向函数传递数组时,将整个数组拷贝一份传入函数导致执行效率低下,C 语言以高效作是最初的设计目标,所以这种方法是不可取的. ...

  6. c语言学习笔记 —— 数组

    1. 数组的内存分配原理. 数组定义  int a[3] = {1,3,11}; 如下写法是错误的: int number; int a[number] = {1,7,9}; 原因是:没有定长的数组初 ...

  7. c语言学习笔记.数组.

    数组: 可以存储一个固定大小的相同类型元素的顺序集合,比如int类型的数组.float类型的数组,里面存放的数据称为“元素”. 所有的数组都是由连续的内存位置组成.最低的地址对应第一个元素,最高的地址 ...

  8. GO 语言学习笔记--数组切片篇

    1.对于make 数组切片,长度和容量需要理解清楚: 容量表示底层数组的大小,长度是你可以使用的大小: 容量的用处在哪?在与当你用 appen d扩展长度时,如果新的长度小于容量,不会更换底层数组,否 ...

  9. Dart语言学习(七)Dart Map类型

    映射(Maps)是无序的键值对: 常用属性: keys 获取所有的key值 values 获取所有的value值 isEmpty 是否为空 isNotEmpty 是否不为空 常用方法: remove( ...

随机推荐

  1. Git config 使用说明(转)

    原文:https://blog.csdn.net/gdutxiaoxu/article/details/79253737

  2. java 任务定时调度(定时器)

    任务定时调度 通过Timer和Timetask,我们可以实现定时启动某个线程. java.util.Timer 在这种实现方式中,Timer类作用是类似闹钟的功能,也就是定时或者每隔一定时间触发一次线 ...

  3. Effective Java 读书笔记(一):创建和销毁对象

    1 构造器 => 静态工厂方法 (1)优势 静态工厂方法有名字 静态工厂方法不必在每次被调用时都产生一个新的对象 静态工厂方法能返回原返回类型的任意子类型的对象 静态工厂方法根据调用时传入的不同 ...

  4. iOS - starckView 类似Android线性布局

    同iOS以往每个迭代一样,iOS 9带来了很多新特性.UIKit框架每个版本都在改变,而在iOS 9比较特别的是UIStackView,它将从根本上改变开发者在iOS上创建用户界面的方式.本文将带你学 ...

  5. STM8 工程模版

    在st官网下载STM8固件库 拷贝固件库到工程目录下 再创建两个目录 user:存放用户文件.自己编写的源文件 project:存放工程文件 拷贝stm8s_conf.h到user目录下 AIR 创建 ...

  6. linux sort命令用法

    sort命令:用于将文本文件内容加以排序,sort可针对文本文件的内容,以行为单位来排序. 命令格式: sort [-bcdfimMnr][-o<输出文件>][-t<分隔字符> ...

  7. 一个让Java事半功倍的反射库

    在Java和Android中,我们常常会使用反射来达到一些兼容的目的.Java原生提供的反射很是麻烦,使用起来很是不方便.比如我们想要调UserManager的静态方法get,使用原生的实现如下 tr ...

  8. C# - 配置动态更新

    生产中经常会遇到修改配置的情况,但是又需要重启应用程序,是不是有点小烦躁.... 下面了解下在不重启情况下,实现配置更新实时生效 public static void SetConfig(string ...

  9. [dev][ipsec][distributed] strongswan如何做热迁移/高可用/High Availability

    问题描述: 原生的基于kernel 的 strongswan 如何做高可用,HA,High Availability 问题分析: 基于我们已知的,ipsec,strongswan的知识.问题分解如下: ...

  10. Python_while语句

    1.while语句: count = 0 while (count<4): count +=1 print('准备放入第'+str(count)+'个杯子') 注:还是要注意一下,条件之后加“: ...