+ 收藏我们

网站模板

网站模板搜索
404模板 营销型模板 外贸网站模板 单页模板 双语模板 标签大全
电话:18630701785
首页 > 站长学院 > Go 中的指针与值接收器 | heap.Interface 与 sort.Interface >

Go 中的指针与值接收器 | heap.Interface 与 sort.Interface

时间:2024-04-06 14:41:05

今天本篇文章带大家了解《Go 中的指针与值接收器 | heap.Interface 与 sort.Interface》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

问题内容
我在heap.Interface包下遇到了priorityqueue示例

链接:https://golang.org/pkg/container/heap/#Interface

对于 heap.Interface 所需的 Push() 和 Pop() 函数,实现在指针接收器上。但对于 sort.Interface 所需的 Swap() 函数,实现是有价值的。

为什么会出现这种差异?

根据我的理解,Push()和Pop()是在指针类型上实现的,因为它们需要更改底层数据。但按照这个逻辑,Swap() 也应该在指针类型上实现。

Swap() 实现如何以及为什么对值起作用,但 Push() 和 Pop() 却不起作用?


解决方案

当需要修改传递的值时,需要指针接收器。在 Swap 的情况下,值本身(这是一个切片)不会被修改,尽管支持该切片的数组确实会被修改。

在 Push 和 Pop 的情况下,切片确实会被修改,因为在这两种情况下长度都会发生变化(在 Push 的情况下,如果底层数组有以下情况,则可能会被新数组替换)已达到其容量)。

有问题可以加入网站技术QQ群一起交流学习

本站会员学习、解决问题QQ群(691961965)

客服微信号:lpf010888

Title