Safe using:
<?php
$cnt = iterator_count(clone $iterator);
?>
(PHP 5 >= 5.1.0, PHP 7, PHP 8)
iterator_count — Подсчитывает количество элементов в итераторе
Подсчитывает количество элементов в итераторе.
iterator_count() не гарантирует сохранение текущей позиции
iterator
.
iterator
Итератор, в котором производится подсчёт.
Количество элементов в итераторе (iterator
).
Версия | Описание |
---|---|
8.2.0 |
Тип параметра iterator был расширен с
Traversable до Traversable|array.
|
Пример #1 Пример использования iterator_count()
<?php
$iterator = new ArrayIterator(array('recipe'=>'pancakes', 'egg', 'milk', 'flour'));
var_dump(iterator_count($iterator));
?>
Результат выполнения приведённого примера:
int(4)
Пример #2 iterator_count() модифицирует позицию
<?php
$iterator = new ArrayIterator(['one', 'two', 'three']);
var_dump($iterator->current());
var_dump(iterator_count($iterator));
var_dump($iterator->current());
?>
Результат выполнения приведённого примера:
string(3) "one" int(3) NULL
Пример #3 iterator_count() в цикле foreach
<?php
$iterator = new ArrayIterator(['one', 'two', 'three']);
foreach ($iterator as $key => $value) {
echo "$key: $value (", iterator_count($iterator), ")\n";
}?>
Результат выполнения приведённого примера:
0: one (3)
Be aware that counting over NoRewindIterator will make items unavailable:
<?php
$iterator = new ArrayIterator(['recipe'=>'pancakes', 'egg', 'milk', 'flour']);
$iterator = new NoRewindIterator($iterator);
var_dump($iterator->current());
var_dump(iterator_count($iterator));
var_dump($iterator->current());
$iterator->rewind(); // Does not work because it's NoRewindIterator
var_dump($iterator->current());
var_dump(iterator_count($iterator));
?>
Output:
<?php
/*
string(8) "pancakes"
int(4)
NULL
NULL
*/
int(0)
?>