微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SplMinHeap或SplMaxHeap是否在逻辑上实现Traversable接口?

如何解决SplMinHeap或SplMaxHeap是否在逻辑上实现Traversable接口?

我注意到SplMinHeapSplMaxHeap实现了Iterator接口,该接口实现了Traversable接口,因此我可以使用iterator_to_array (Traversable $iterator) : arrayforeach语法来迭代这两个类的任何实例。

SplMaxHeap extends SplHeap implements Iterator,Countable {

SplMinHeap extends SplHeap implements Iterator,Countable {

但是当我重复迭代SplMinHeap / SplMaxHeap的实例时,在第一次迭代后,我得到了一个空数组。看起来第一次迭代破坏了SplMinHeap / SplMaxHeap的内部结构。

<?PHP
$minHeap = new SplMinHeap();
$minHeap->insert(15);
$minHeap->insert(5);
$minHeap->insert(10);

foreach ($minHeap as $val) echo $val,PHP_EOL;

var_dump(iterator_to_array($minHeap));  // empty array
var_dump(iterator_to_array($minHeap));  // empty array

是的,我们可以遍历/迭代该数据结构,就像其声明的类一样,但仅一次。符合逻辑吗?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。