文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-02-08 21:53

关注

在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])。

如果推送其他元素(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 结构体中的切片的详细内容,更多请关注编程网其它相关文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯