Go 中的指针与值接收器 | heap.Interface 与 sort.Interface
对于一个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
的情况下,值本身(这是一个切片)不会被修改,尽管支持该切片的数组确实会被修改。
在 Push
和 Pop
的情况下,切片确实会被修改,因为在这两种情况下长度都会发生变化(在 Push
的情况下,如果底层数组有以下情况,则可能会被新数组替换)已达到其容量)。
本篇关于《Go 中的指针与值接收器 | heap.Interface 与 sort.Interface》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注编程网公众号!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341