理解Golang中的數(shù)組(array)、切片(slice)和map
我比較喜歡先給出代碼,然后得出結(jié)論
數(shù)組
package main
import (
"fmt"
)
func main() {
arr := [...]int{1, 2, 3}
//打印初始的指針
fmt.Printf("the pointer is : %p \n", &arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", &any)
}
結(jié)果
1 the pointer is : 0xc082008580
2 the pointer is : 0xc0820001d0
切片
package main
import (
"fmt"
)
func main() {
arr := make([]int, 3)
//打印初始的指針
fmt.Printf("the pointer is : %p \n", arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
}
結(jié)果
1 the pointer is : 0xc082008580
2 the pointer is : 0xc082008580
map
package main
import (
"fmt"
)
func main() {
arr := make(map[int]string)
//arr := [3]int{1, 2, 3}
//打印初始的指針
fmt.Printf("the pointer is : %p \n", arr)
printPointer(arr)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
}
運(yùn)行結(jié)果
1 the pointer is : 0xc082007c80
2 the pointer is : 0xc082007c80
由此,我們看到數(shù)組本身傳過去的是值,傳到函數(shù)之后,被開辟了另外一個(gè)空間。
因?yàn)閿?shù)組就是他本身。這一句好像不太好理解。
這是切片 arr := make([]int, 3) 而arr 本身不是一個(gè)數(shù)組,至少不是我們所想要的指向的一個(gè)數(shù)組。只是arr里有一個(gè)地址指向數(shù)組。
這么舉個(gè)例子:
arr := [...]int{1,2,3,4,5} 這是一個(gè)數(shù)組,懂得go語言的都明白。 arr本身就是數(shù)組
arrSlice := arr[0:5] 這是一個(gè)切片。 打印所得的值是一樣的,和上面。 arrSlice本身不是數(shù)組,只是arrSlice本身有一個(gè)值是指向arr的指針。
切片是指一個(gè)結(jié)構(gòu)體,大體結(jié)構(gòu)像這樣:
struct slice{
ptr *Elem
len int
cap int
}
也就是說,上面的arrSlice其實(shí)是一個(gè)結(jié)構(gòu)體。里面有一個(gè)屬性 ptr指向數(shù)組 arr
其實(shí)arrSlice也是傳到函數(shù)里,也是進(jìn)行了復(fù)制。但是盡管傳過去是一個(gè)復(fù)制的結(jié)構(gòu)體,他的屬性ptr,沒有變。還是一個(gè)指向原數(shù)組的指針。
下面的例子見證他自己傳過去,是一個(gè)復(fù)制的過程:
package main
import (
"fmt"
)
func main() {
arrSlice := make([]int, 4)
fmt.Printf("the pointer is : %p \n", arrSlice)
fmt.Printf("the pointer is : %p \n", &arrSlice) //這是arrSlice本身的指針,也就是結(jié)構(gòu)體的指針
printPointer(arrSlice)
}
func printPointer(any interface{}) {
fmt.Printf("the pointer is : %p \n", any)
fmt.Printf("the pointer is : %p \n", &any) //打印傳過來的結(jié)構(gòu)體arrSlice的指針
}
看結(jié)果:
the pointer is : 0xc0820085a0
the pointer is : 0xc082008580
the pointer is : 0xc0820085a0
the pointer is : 0xc0820001d0
第1、3個(gè)的打印是打印這個(gè)結(jié)構(gòu)體的ptr屬性,也就是指向數(shù)組的指針。
其實(shí)這個(gè)結(jié)構(gòu)體傳到函數(shù)里,是一個(gè)復(fù)制的過程,第2、4的指針不一樣。
大家在對照下面的圖片理解一下:
相關(guān)文章
GOLANG使用Context管理關(guān)聯(lián)goroutine的方法
這篇文章主要介紹了GOLANG使用Context管理關(guān)聯(lián)goroutine的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01利用golang進(jìn)行OpenCV學(xué)習(xí)和開發(fā)的步驟
目前,OpenCV逐步成為一個(gè)通用的基礎(chǔ)研究和產(chǎn)品開發(fā)平臺,下面這篇文章主要給大家介紹了關(guān)于利用golang進(jìn)行OpenCV學(xué)習(xí)和開發(fā)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-09-09Go語言特點(diǎn)及基本數(shù)據(jù)類型使用詳解
這篇文章主要為大家介紹了Go語言特點(diǎn)及基本數(shù)據(jù)類型使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-03-03關(guān)于Golang變量初始化/類型推斷/短聲明的問題
這篇文章主要介紹了關(guān)于Golang變量初始化/類型推斷/短聲明的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02破解IDEA(Goland)注冊碼設(shè)置 license server一直有效不過期的過程詳解
這篇文章主要介紹了破解IDEA(Goland)注冊碼設(shè)置 license server一直有效不過期,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11