如何解决SplMinHeap或SplMaxHeap是否在逻辑上实现Traversable接口?
我注意到SplMinHeap
或SplMaxHeap
实现了Iterator
接口,该接口实现了Traversable
接口,因此我可以使用iterator_to_array (Traversable $iterator) : array
或foreach
语法来迭代这两个类的任何实例。
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 举报,一经查实,本站将立刻删除。