黑马模板网专注企业网站模板制作,包括企业pbootcms网站模板,静态网页模板,网站源码下载,HTML网站模板等等。
免责声明:本站所有资源(模板、图片)搜集整理于互联网或者网友提供,仅供学习与交流使用,如果不小心侵犯到你的权益,请及时联系我们删除该资源。
今天本篇文章带大家了解《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 的情况下,如果底层数组有以下情况,则可能会被新数组替换)已达到其容量)。