feat(array): 添加数组拷贝和遍历的学习内容 添加了数组拷贝的详细说明,包括值拷贝的概念和示例代码, 以及数组遍历的方法介绍。同时创建了相应的演示程序和 draw.io图表来可视化数组拷贝过程。 ```
93 lines
2.1 KiB
Markdown
93 lines
2.1 KiB
Markdown
# 数组
|
||
|
||

|
||
|
||
[课件](https://gitee.com/infraboard/go-course/blob/master/zh-cn/base/array.md)
|
||
|
||
## 核心概念
|
||
|
||
根据容器里面数据类型不同,直接分配分配内存(连续的内存地址空间), 内存地址有开始和结束, 访问里面的对象, 我们需要传递索引, (这个索引会根据当前数据结构int8(一个字节) (ADDR,ADDR(+1字节))
|
||
|
||
由于是连续内存地址, 访问速度极高
|
||
|
||
+ 长度固定
|
||
+ 类型一致(静态语言)
|
||
|
||
```go
|
||
# 数组表示
|
||
[]string{}, []int{}, []bool{},
|
||
# 特殊情况
|
||
[]any{}
|
||
```
|
||
|
||
## 定义数组
|
||
|
||

|
||
|
||
1. 数组声明 + 初始化
|
||
```go
|
||
// 声明数组: [长度]type
|
||
var arr [10]int64
|
||
// 这个数组的零值是 【0,0,0,0,0,0,0,0,0,0】
|
||
// 初始化数组
|
||
arr = [10]int64{1,2,3,4,5,6,7,8,9,10}
|
||
|
||
// 简短方式(声明 + 初始化)
|
||
// := 简单声明,
|
||
arr := [10]int64{1,2,3,4,5,6,7,8,9,10}
|
||
|
||
// 动态推算大小 ... => 10, 这种方式不怎么使用
|
||
arr := [...]int64{1,2,3,4,5,6,7,8,9,10}
|
||
```
|
||
|
||
2. 赋值: 基础类型的容器,表示多个
|
||
```go
|
||
// 找到元素(数组里面的插槽), 插槽编号 就是索引(0 - 结束)
|
||
arr[0] = 1
|
||
arr[1] = 2
|
||
arr[2] = 3
|
||
```
|
||
|
||
## 数组拷贝
|
||
|
||
go 默认就是值拷贝, = 赋值 也是 值copy
|
||
|
||
1. 浅拷贝: 创建一个新数组,新数组的元素和原数组的元素是相同的,但是两个数组的元素是两个不同的对象
|
||
|
||
```go
|
||
func main() {
|
||
// ipv4 4字节表示一个ipv4地址, 简短声明: 127.0.0.1
|
||
ip := [4]byte{127, 0, 0, 1}
|
||
fmt.Println("ip1:", ip)
|
||
|
||
// 如何copy这个数组, 这个赋值有没有完成copy
|
||
// 怎么理解数组的复制 是值拷贝
|
||
//
|
||
// a := 1
|
||
// b := a
|
||
// b = 2
|
||
// fmt.Println("a:", a)
|
||
// fmt.Println("b:", b)
|
||
// 数组: 一片连续的地址控制
|
||
// ip2 := ip (ip 有自己连续的地址空间)
|
||
// ip2[4]byte{} (ip2 申请的连续地址)
|
||
// Go 默认是值拷贝(重要)
|
||
// ip 的值 传递给 ip2
|
||
// ip2 和 ip 是两个不同的数组, 互不影响
|
||
|
||
ip2 := ip
|
||
fmt.Println("ip2:", ip2)
|
||
|
||
// 修改ip2 不会影响ip
|
||
ip2[0] = 10
|
||
fmt.Println("ip1:", ip)
|
||
fmt.Println("ip2:", ip2)
|
||
}
|
||
```
|
||
|
||
## 数组遍历
|
||
|
||
1. 循环遍历(for)
|
||
```go
|
||
|
||
``` |