首页 >后端开发 >Golang >如何理解 Golang 结构体中的切片

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

WBOY
WBOY转载
2024-02-08 21:45:12954浏览

如何理解 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),则

就是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删除