PHP Conference Nagoya 2025

Класс NoRewindIterator

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

Введение

Итератор игнорирует операции перемотки. Это позволяет обрабатывать итератор в нескольких частичных циклах foreach.

Обзор класса

class NoRewindIterator extends IteratorIterator {
/* Методы */
public __construct(Iterator $iterator)
public current(): mixed
public key(): mixed
public next(): void
public rewind(): void
public valid(): bool
/* Наследуемые методы */
}

Содержание

Добавить

Примечания пользователей 1 note

up
7
Anonymous
4 years ago
As its name implies, NoRewindIterator doesn't invoke the "rewind" method when It reaches the end of the iterator.

Let's demonstrate it by two examles.

In this example the "rewind" method will be invoked after when the "foreache" reaches its end, so, we can repeat printing the same values as many times as we want:

<?PHP
$iterator
= new ArrayIterator(['PHP', 'Python', 'Go']);

foreach (
$iterator as $item) {
echo
$item.PHP_EOL;
}

foreach (
$iterator as $item) {
echo
$item.PHP_EOL;
}
?>

By using the NoRewindIterator, the "rewind" won't be invoked, so, we can't do as we did in previous example:

<?PHP
$iterator
= new ArrayIterator(['PHP', 'Python', 'Go']);
$iterator = new NoRewindIterator($iterator);

foreach (
$iterator as $item) {
echo
$item.PHP_EOL;
}

// doesn't do anything
foreach ($iterator as $item) {
echo
$item.PHP_EOL;
}

?>
To Top