共计 1784 个字符,预计需要花费 5 分钟才能阅读完成。
一、数组
定义:
var 数组名 [数组大小]数组类型
var a [5]int // 定义完数组各个元素就有默认值
- 数组的地址能够通过数组名来获取 &arr
- 数组的第一个元素的地址,就是数组的首地址
- 数组的各个元素的地址距离是根据数组类型决定的,如 int64->8
arr[0]的地址加 8 个字节就是 arr[1] 的地址
四种初始化形式:
func main() {var arr [3]int = [3]int{1, 2, 3}
var arr2 = [3]int{1, 2, 3}
var arr3 = [...]int{1, 2, 3}
var arr3 = [...]string{0: "xxx", 1: "zzz"}
}
for range 遍历数组:
func main() {
// 第一个返回值 index 是数组的下标
// 第二个返回值 value 是下标对应的值
// 他们都是仅在 for 循环外部可见的变量
var arr3 = [...]string{0: "xxx", 2: "zzz"}
for index,value := range arr3 {fmt.Printf("索引:%v, 值:%vn", index, value)
}
}
一、切片
切片是数组的援用
func main() {var intArr [5]int = [...]int {1, 2, 33, 44, 56}
// 援用数组下标为 1,最初的下标为 3(但不包含 3)22, 33
slice := intArr[1:3]
fmt.Println("数组:", intArr)
fmt.Println("切片:", slice)
fmt.Println("切片个数:", len(slice))
fmt.Println("切片容量:", cap(slice)) // 切片的容量能够动态变化
}
切片内存存储 切片不存储任何元素,只是对现有数组的援用,对切片的任何批改,都反映在底层数组中。
slice 从底层来说,其实就是一个数据结构(struct 构造体)
type slice struct {
ptr *[2]int // 数组的第几个元素的地址
len int
cap int
}
切片的应用形式
- 定义一个切片,而后让切片援用一个曾经创立好的数组。
var intArr [5]int = [...]int {1, 2, 33, 44, 56}
slice := intArr[1:3]
- 通过 make 来创立切片。
// var 切片名 []type = make([]int, len, cap)
// 对于切片必须先 make 再应用
var slice []int = make([]int, 2, 4)
通过 make 形式创立的切片对应的数组是由 make 底层保护,对外不可见,只能通过 slice 去拜访各个元素
- 定义一个切片,间接就指定具体数组,应用原理相似 make 的形式
var slice []int = []int{1, 2, 4}
切片细节
var slice = arr[0:end] 能够简写成 var slice = arr[:end]
var slice = arr[start:len(arr)] 能够简写成 var slice = arr[start:]
var slice = arr[0:len(arr)] 能够简写成 var slice = arr[:] 切片能够持续切片
append 内置函数,能够对切片进行动静减少
var slice []int = []int{1, 2, 3}
slice2 := append(slice, 400, 500)
切片 append 操作的实质是对数组扩容
go 底层会创立一个新的数组 newArr
将 slice 原来蕴含的元素拷贝到新的数组 newArr
slice 从新援用到 newArr,newArr 底层保护,程序员不可见
切片的拷贝 copy,a 和 slice 的数据空间是独立的,互不影响。
var slice []int = []int{1, 2, 3}
var a = make([]int, 10)
copy(a, slice)
string 和切片关系
var str string = "hello@atguigu"
// 获取 atguigu
slice := str[6:]
// string 是不可变的,不能 str[0] = "z", 来批改字符串
// 要批改可将 string->[]byte 或 string->[]rune
arr1 := []byte(str)
arr1[0] = 'z'
str = string(arr1)
// []byte 是通过字节解决的,不能解决中文,因为一个中文占 3 个字节,须要转成[]rune
正文完