登录
首页 >  Golang >  Go问答

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

来源:stackoverflow

时间:2024-04-04 22:06:37 467浏览 收藏

对于一个Golang开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《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 的情况下,值本身(这是一个切片)不会被修改,尽管支持该切片的数组确实会被修改。

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

本篇关于《Go 中的指针与值接收器 | heap.Interface 与 sort.Interface》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>