首頁  >  文章  >  後端開發  >  如何理解 Golang 結構體中的切片

如何理解 Golang 結構體中的切片

WBOY
WBOY轉載
2024-02-08 21:45:12898瀏覽

如何理解 Golang 结构体中的切片

在Golang中,結構體是一種自訂的資料類型,它可以包含多個欄位。而在結構體中,切片是一種動態數組,可以根據需要進行擴容或縮小。然而,理解Golang結構體中的切片可能會引起一些困惑。在本文中,php小編柚子將為您詳細解釋Golang結構體中切片的工作原理和使用方法,幫助您更好地理解和應用這一特性。無論您是初學者還是有一定經驗的開發者,本文都將為您提供有價值的知識和實用的技巧,讓您在Golang開發中更加得心應手。

問題內容

我是 Golang 新手,我正在嘗試理解指標

type deque struct {
    indexes []int
}

func (d *deque) push(i int) {
    d.indexes = append(d.indexes, i)
}

這裡的索引是一個切片而不是指向切片的指標。

索引實際上是如何儲存在記憶體中的?

例如:當我們啟動一個deque實例時,我們稱它為dq,在記憶體中,dq的位址是0x1001(我們稱它為adr(dq))。

adr(dq)中儲存的變數是什麼?是指向數組的指標嗎?

0x1001 -> Ox8009(陣列第一個元素的位址)

還是陣列本身?

0x1001 -> 切片的第一個元素

# 0x1002 -> 切片的第二個元素

當我們:

時會發生什麼
d.indexes = append(d.indexes, i)

如果我們定義有什麼差別:

type deque struct {
    indexes *[]int
}

解決方法

例如,deque實例在記憶體中的位址為0x1001。 它初始化:

0x1001 -> [indexes: nil]

如果新增元素(dq.push(12)):

0x1001 -> [length: 1, capacity: 1, data: 0x3001 (pointer to data)]
0x3001 -> [12]

0x1001處的切片結構包含有關切片長度和容量的資訊(長度:1,容量:1),實際資料儲存在另一個位址(假設0x3001,陣列[12])。 p>

如果推送其他元素(dq.push(34)、dq.push(56))。

0x1001 -> [length: 3, capacity: 4, data: 0x5001 (new pointer to data due to capacity, capacity doubles)]
0x5001 -> [12, 34, 56]

程式碼1:

type deque struct {
    indexes []int
}
func (d *deque) push(i int) {
    d.indexes = append(d.indexes, i)
}
func main() {
    dq := deque{}
    dq.push(12)
    dq.push(34)
    dq.push(56)
    fmt.Println("Deque elements:", dq.indexes)
}

輸出1:

Deque elements: [12 34 56]

如果使用指向切片的指標 (*[]int) 而不是切片本身 ([]int)。這意味著indexes欄位將保存一個指向切片的指針,並且在使用它之前需要初始化該指針。

如果新增元素(dq.push(12)),則0x2001就是indexes所指向的底層切片結構的位址

0x1001 -> [indexes: 0x2001 (pointer to slice)]
0x2001 -> [length: 1, capacity: 1, data: 0x3001 (pointer to data)]
0x3001 -> [12]

0x2001處的切片結構包含切片的長度和容量資訊(長度:1,容量:1),實際資料儲存在另一個位址(0x3001,陣列[12])。

如果推送其他元素(dq.push(34)、dq.push(56))。

0x1001 -> [indexes: 0x2001 (pointer to slice)]
0x2001 -> [length: 3, capacity: 4, data: 0x5001 (new data pointer, due to capacity, capacity doubles)]
0x5001 -> [12, 34, 56]

程式碼2:

type deque struct {
    indexes *[]int
}

func (d *deque) push(i int) {
    if d.indexes == nil {    // initialize the slice if it's nil
        d.indexes = &[]int{}
    }
    *d.indexes = append(*d.indexes, i)
}

func main() {
    dq := deque{}
    dq.push(12)
    dq.push(34)
    dq.push(56)
    fmt.Println("Deque elements:", *dq.indexes)
}

輸出2:

Deque elements: [12 34 56]

以上是如何理解 Golang 結構體中的切片的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:stackoverflow.com。如有侵權,請聯絡admin@php.cn刪除