Golang常用數(shù)據(jù)結(jié)構(gòu)

數(shù)組

聲明數(shù)組

數(shù)組同樣使用倒置的方式來(lái)聲明,并且聲明數(shù)組的時(shí)候需要指定數(shù)組長(zhǎng)度。所以聲明數(shù)組需要使用[數(shù)組長(zhǎng)度]類(lèi)型的方式來(lái)聲明,如果需要在聲明的同時(shí)初始化,還可以添加{}初始化列表。

//聲明數(shù)組
var array1 [2]int
array1[0] = 1
array1[1] = 2
fmt.Println(array1)
//聲明的同時(shí)初始化
array2 := [3]int{1, 2, 3}
fmt.Println(array2)

數(shù)組一旦聲明,長(zhǎng)度就是固定不可變的了。

訪(fǎng)問(wèn)數(shù)組

這個(gè)比較簡(jiǎn)單,和一般編程語(yǔ)言一樣。下面是一個(gè)小例子。

//訪(fǎng)問(wèn)數(shù)組
numbers := [10]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}
for i := 0; i < len(numbers); i++ {
    fmt.Print(numbers[i])
}
fmt.Println()

切片

數(shù)組雖然是一種重要的工具,但是由于長(zhǎng)度固定所以有時(shí)候不太好用。Golang提供了另一個(gè)強(qiáng)大的工具——切片。所以在實(shí)際編碼中切片更加常用。

聲明切片

切片的類(lèi)型和數(shù)組類(lèi)似,區(qū)別在于切片不能指定方括號(hào)內(nèi)部的數(shù)字。如果打印切片,結(jié)果和數(shù)組類(lèi)似。

array := [7]int{1, 2, 3, 4, 5, 6, 6}
var numbers []int = array[:]
fmt.Println(numbers)

切片和數(shù)組在很多地方都相同,不過(guò)需要記住,切片只是一個(gè)視圖,對(duì)切片的修改都會(huì)反映到底層數(shù)組上。如果修改了源數(shù)組,那么切片也會(huì)反映出修改。

array[6] = 7
fmt.Println(numbers)

如果只需要使用切片,也可以不聲明底層數(shù)組,直接使用切片字面量,也就是[]類(lèi)型{初始化列表}的形式。

numbers2 := []int{1, 2, 3, 4, 5}
fmt.Println(numbers2)

切片屬性

切片有兩個(gè)重要的屬性,長(zhǎng)度容量。長(zhǎng)度指的是切片包含的元素?cái)?shù)量,容量指的是切片對(duì)應(yīng)的底層數(shù)組的長(zhǎng)度。Golang有兩個(gè)內(nèi)置函數(shù)可以計(jì)算切片的長(zhǎng)度和容量。

fmt.Printf("長(zhǎng)度:%d, 容量:%d", len(numbers), cap(numbers))

切片的默認(rèn)值是nilnil值切片的長(zhǎng)度和容量都是0,而且沒(méi)有底層數(shù)組。

切片操作

如果了解Python這門(mén)語(yǔ)言的話(huà),應(yīng)該對(duì)切片操作很熟悉。在Go語(yǔ)言中,切片操作也是類(lèi)似的。

首先先來(lái)看看切片的下標(biāo)。切片下標(biāo)可以被忽略,當(dāng)它被忽略的時(shí)候?qū)?yīng)的下標(biāo)會(huì)延伸至對(duì)應(yīng)切片端點(diǎn)處。舉個(gè)例子,對(duì)于一個(gè)有5個(gè)元素的切片a來(lái)說(shuō),a[0:5]、a[0:]、a[:5]a[:]都是等價(jià)的,指的都是整個(gè)切片。

Golang內(nèi)置了一個(gè)函數(shù)make,可以幫助我們快速創(chuàng)建切片,它的第一個(gè)參數(shù)是切片類(lèi)型,第二個(gè)參數(shù)是長(zhǎng)度,第三個(gè)參數(shù)是容量。

numbers3 := make([]int, 5, 10)
fmt.Printf("長(zhǎng)度:%d, 容量:%d\n", len(numbers3), cap(numbers3))

如果要向切片追加元素,使用內(nèi)置函數(shù)append,這個(gè)函數(shù)返回追加之后的切片。如果切片的容量不足以容納所有元素,Golang會(huì)自動(dòng)分配新的底層數(shù)組,并將對(duì)應(yīng)的切片返回。

numbers = append(numbers, 8, 9, 10)
fmt.Println(numbers)

迭代

Golang有一個(gè)迭代關(guān)鍵字,可以用來(lái)迭代切片和map。使用它迭代切片的時(shí)候,會(huì)返回切片對(duì)應(yīng)元素的下標(biāo)和元素值,如果只寫(xiě)一個(gè)值的話(huà),那么就會(huì)迭代下標(biāo)。下面的例子利用了這兩個(gè)特性,先填充了一個(gè)切片,然后輸出它的元素。

numbers := make([]int, 3)
for i := range numbers {
    numbers[i] = i
}
fmt.Println(numbers)
for i, v := range numbers {
    fmt.Printf("numbers[%d]=%d\n", i, v)
}
fmt.Println()

如果下標(biāo)和值中想要忽略某一個(gè),可以使用_下劃線(xiàn)代替。

for _, value := range numbers {
...
}

Map

Map又叫關(guān)聯(lián)數(shù)組,用于存儲(chǔ)鍵值對(duì)的集合。Map的默認(rèn)值是nil,但是需要注意,一個(gè)nil的Map不能向其添加值。

創(chuàng)建Map

創(chuàng)建Map使用全局函數(shù)makemake函數(shù)的參數(shù)是map[鍵類(lèi)型]值類(lèi)型,這樣就會(huì)創(chuàng)建一個(gè)可用的Map。然后就可以向它填充元素了。

map1 := make(map[int]int)
map1[1] = 1
map1[2] = 2
fmt.Println(map1)

Map字面值

上面的例子首先使用make函數(shù)創(chuàng)建一個(gè)Map,然后向其添加值。我們可以直接使用Map字面值創(chuàng)建一個(gè)帶有初始值的Map。Map字面值的形式類(lèi)似map[鍵類(lèi)型]值類(lèi)型{鍵:值,鍵:值, ....}。需要注意在Map字面值中,每個(gè)鍵值對(duì)后面的逗號(hào)是必須的,所以哪怕是最后一個(gè)鍵值對(duì)仍然需要逗號(hào)。

所以對(duì)于上面的例子可以直接使用一個(gè)Map字面值。

map2 := map[int]int{
    1: 1,
    2: 2,
}
fmt.Println(map2)

Map操作

在上面已經(jīng)展示了最基本的Map操作,那就是添加元素。對(duì)于Map來(lái)說(shuō),如果向不存在的鍵賦值,就會(huì)將這個(gè)鍵值對(duì)添加到Map中。也可以在獲取鍵的時(shí)候同時(shí)檢查是否存在,如果不存在,那么就會(huì)返回對(duì)應(yīng)值類(lèi)型的默認(rèn)值。

//Map操作
map3 := make(map[int]int)
//增加
map3[1] = 1
//修改
map3[1] = 2
//刪除
delete(map3, 1)
//檢查鍵是否存在
value, ok := map3[1]
fmt.Printf("%v %v", value, ok)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 出處---Go編程語(yǔ)言 歡迎來(lái)到 Go 編程語(yǔ)言指南。本指南涵蓋了該語(yǔ)言的大部分重要特性 Go 語(yǔ)言的交互式簡(jiǎn)介,...
    Tuberose閱讀 18,731評(píng)論 1 46
  • 前言 把《C++ Primer》[https://book.douban.com/subject/25708312...
    尤汐Yogy閱讀 9,675評(píng)論 1 51
  • New Vocabulary: 1.mogul:a businessman or businesswoman wh...
    二白_a00c閱讀 391評(píng)論 0 0
  • 一直想要提高英語(yǔ),也聽(tīng)了很多英語(yǔ)學(xué)習(xí)方法,最簡(jiǎn)單粗暴的方式就是直接找一本感興趣的原版書(shū)去讀,于是開(kāi)始讀笑來(lái)老師推薦...
    大慶的慶閱讀 301評(píng)論 0 3
  • 為什么這么久了我還是會(huì)喜歡你,可能是因?yàn)槲业浆F(xiàn)在都沒(méi)有擁有過(guò)你。 一 從傻乎乎的初中到...
    磨嘰又嘰歪的耗子君閱讀 543評(píng)論 2 2

友情鏈接更多精彩內(nèi)容