对于一个golang开发者来说,牢固扎实的基础是十分重要的,编程网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Go 中的指针与值接收器 | heap.Interface 与 sort.
对于一个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的相关知识,请关注编程网公众号!
--结束END--
本文标题: Go 中的指针与值接收器 | heap.Interface 与 sort.Interface
本文链接: https://lsjlt.com/news/596850.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-04-05
2024-04-05
2024-04-05
2024-04-04
2024-04-05
2024-04-05
2024-04-05
2024-04-05
2024-04-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0