猿问

指向切片和数组的指针

我正在查看 Go 的堆包 ( https://golang.org/pkg/container/heap/ ) Priority Queue 示例并遇到了这个:


type PriorityQueue []*Item

...

func (pq *PriorityQueue) Pop() interface{} {

    old := *pq

    n := len(old)

    item := old[n-1]

    item.index = -1 // for safety

    *pq = old[0 : n-1]

    return item

当我开始玩弄这段代码以确保我理解它时,我尝试了:


item := *pq[0] // error

这使您键入 *[]T 不支持索引。但如果你这样做:


item := (*pq)[0] // all is well

这是类型断言吧?希望有人能解释这里发生了什么。


这是一些快速显示的代码:https : //play.golang.org/p/uAzYASrm_Q


慕姐8265434
浏览 201回答 1
1回答

牧羊人nacy

对您有用的不是类型断言 - 它是操作顺序。问题的根源在于索引先于指针的取消引用。一旦将大括号放在指针解除引用周围,一切都会很好,因为索引应用于现在解除引用的PriorityQueue实例。您不需要对数组指针执行此操作,因为它们会自动取消引用 - 索引数组和切片之间的细微差别在这里解释:Go 编程语言规范 - 索引表达式对于a数组类型A:常量索引必须在范围内如果x在运行时超出范围,则会发生运行时恐慌a[x]在索引的数组元素x的类型和a[x]被的元素类型A对于a指向数组类型的指针:a[x] 是简写 (*a)[x]对于a切片类型S:如果x在运行时超出范围,则会发生运行时恐慌a[x]在索引片元件x的类型和a[x]被的元素类型S
随时随地看视频慕课网APP

相关分类

Go
我要回答