我正在查看 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
1 回答
牧羊人nacy
TA贡献1862条经验 获得超7个赞
对您有用的不是类型断言 - 它是操作顺序。
问题的根源在于索引先于指针的取消引用。一旦将大括号放在指针解除引用周围,一切都会很好,因为索引应用于现在解除引用的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
- 1 回答
- 0 关注
- 200 浏览
添加回答
举报
0/150
提交
取消
