詳細介紹Go語言之陣列與切片

2022-09-25 01:57:11 字數 4069 閱讀 7817

目錄

陣列是同一型別元素的集合,可以放多個值,但是型別一致,記憶體中連續儲存

go 語言中不允許混合不同型別的元素,而且陣列的大小,在定義階段就確定了,不能更改

// 定義乙個大小為3的string型別和int8型別的陣列,裡面可以放3個字串和3個數字

var names [3]string

var ages [3]int8

fmt.println(names, ages) // 輸出:[ ] [0 0 0]

var ages [3]int8

ages[0] = 18

ages[2] = 22

fmt.println(ages)

fmt.println(ages[1])

// 輸出

[18 0 22]

0// 方式一:

var ages [3]int = [3]int

fmt.println(ages) // 輸出:[1 2 3]

// 方式二:

var ages = [3]int

fmt.println(ages) // 輸出:[1 2 3]

// 方式三:...後面放幾個值,陣列大小就是多少

var ages = [...]int

fmt.println(ages) // 輸出:[1 2 3 4 5 6 7 8]

// 方式四:

ages := [...]int

fmt.println(ages) // 輸出:[1 2 3 4 8]

var a [2]int = [2]int

var b [2]int = [2]int

b = a // 如果不是同一種型別,不允許相互賦值

fmt.println(b)

因為陣列是值型別,go 函式傳參,都是copy傳遞,如果是值型別,函式內改了,不會影響原來的

var a = [2]int

fmt.println(a) // [1 2]

test(a) // [99 2]

fmt.println(a) // [1 2]

func test(a [2]int)

var a = [2]int

fmt.println(len(a)) // 輸出:2

// 普通迴圈

var a = [...]int

for i := 0; i < len(a); i++

// 通過 range 來迴圈(range不是乙個內建函式,是乙個關鍵字如:for,if,else)

// 如果用乙個變數接收,這個值是可迭代的索引

// 如果用兩個變數接收,這兩個變數乙個是索引,乙個是具體的值

var a = [...]int

for i, value := range a

// 不要索引只要值迴圈列印

for _, value := range a

var a [3][3]int // 定義

a[0][1] = 20 // 使用

fmt.println(a) // 輸出:[[0 20 0] [0 0 0] [0 0 0]]

// 定義並賦初始值

var a [3][3]int = [3][3]int, , }

fmt.println(a) // 輸程式設計客棧出:[[1 0 0] [2 3 4] [5 6 0]]

// 迴圈多維陣列

var a [3][3]int = [3][3]int, , }

for _, value := range a

}// 在索引為5和7的位置指定初始化值

var ages [10]int = [10]int

fmt.println(ages) // 輸出:[0 0 0 0 0 55 0 77 0 0]

切片是由陣列建立的一種方案、靈活且功能強大的包裝(wrapper)。

它本身不擁有任何資料,只對現有陣列的引用。

// 定義乙個陣列

var a = [10]int

// 基於陣列,做乙個切片

b := a[:]

fmt.println(b) // 輸出:[9 8 7 6 5 4 3 2 1 0]

fmt.printf("%t", b) // 輸出:int 中括號中不帶東西,就是切片型別

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 1 0]

fmt.printf("%t", a) // 輸出:[10]int

var a = [10]int

b := a[:]

fmt.println(b[0]) // 輸出:9

fmt.println(b[2]) // 輸出:7

var a = [10]int

b := a[:]

b[0] = 99 // 修改切片

fmt.println(b) // 輸出:[99 8 7 6 5 pusevejxc4 3 2 1 0]

// 陣列會被修改

fmt.println(a) // 輸出:[99 8 7 6 5 4 3 2 1 0]

var a = [10]int

b := a[:]

a[1] = 99 // 修改陣列

fmt.println(a) // 輸出:[9 99 7 6 5 4 3 2 1 0]

// 切片也會被修改

fmt.println(b) // 輸出:[9 99 7 6 5 4 3 2 1 0]

var a = [10]int

b := a[3:6]

// 修改切片

b[0] = 66

fmt.println(b) // 輸出:[66 5 4]

fmt.println(a) // 輸出:[9 8 7 66 5 4 3 2 1 0]

// 修改陣列

a[4] = 55

fmt.println(b) // 輸出:[66 55 4]

fmt.println(a) // 輸出:[9 8 7 66 55 4 3 2 1 0]

var a = [10]int

b := a[3:5]

c := a[4:6]

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 1 0]

fmt.println(b) // 輸出:[6 5]

fmt.println(c) // 輸出:[5 4]

b[1] = 555

fmt.println(a) // 輸出:[9 8 7 6 555 4 3 2 1 0]

fmt.println(b) // 輸出:[6 555]

fmt.println(c) // 輸出:[555 4]

var a = [10]int

b := a[3:7]

fmt.println(b) // 輸出:[6 5 4 3]

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 1 0]

// 切片長度

fmt.println(len(b)) // 輸出:4

// 切片容量(我最多能存多少值,從切片的起始位置開始往後所有的,從索引為3開始)

fmt.println(cap(b)) // 輸出:7

var a = [10]int

b := a[6:8]

b = append(b,11)

b = append(b,22)

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 11 22]

// 追加到臨界點了在追加

b = append(b,33)

b = append(b,44)

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 11 22]

fmt.println(b) // 輸出:[3 2 11 22 33 44]

// 陣列長度不會在變了,他會在原來基礎上翻倍,把我原來那個值copy到我新的陣列上a和b已經沒有關係了

b[0] = 33

fmt.println(b) // 輸出:[33 2 11 22 33 44]

fmt.println(a) // 輸出:[9 8 7 6 5 4 3 2 11 22]

go語言之陣列與切片

都屬於集合類的型別,它們的值用來儲存某一型別的值。本質上來說,我們可以把切片看做是對陣列的一層簡單的封裝,每個切片的底層資料結構都是陣列,它可以看作是對陣列某個連續片段的引用,這裡需要注意的幾點是 我們可以通過切片字面量表示式int和內建make函式make int,5,6 初始化乙個切片,也可以通...

go語言之切片

go語言陣列和切片的異同 go 語言切片是對陣列的抽象。go 陣列的長度不可改變,在特定場景中這樣的集合就不太適用,go中提供了一種靈活,功能強悍的內建型別切片 動態陣列 與陣列相比切片的長度是不固定的,可以追加元素,在追加時可能使切片的容量增大。下面看具體例項 package main impor...

go語言之陣列

陣列是go語言程式設計中最常用的資料結構之一,陣列中的每個資料被稱為陣列元素,乙個陣列中元素的個數被稱為陣列的長度。陣列的宣告方法 var arr 32 int 宣告乙個長度為32的陣列,陣列中的元素為int var arr 12 int 宣告乙個長度為12的陣列,陣列中的元素為 int var a...