===== Интерфейс Iterator =====
**Итератор** — это поведенческий паттерн, позволяющий последовательно обходить сложную коллекцию, без раскрытия деталей её реализации.
Интерфейс для внешних итераторов или объектов, которые могут повторять себя изнутри.\\
====Обзор интерфейса====
Iterator extends Traversable {
/* Методы */
abstract public current ( ) : mixed
abstract public key ( ) : scalar
abstract public next ( ) : void
abstract public rewind ( ) : void
abstract public valid ( ) : bool
}
====Предопределенные итераторы====
PHP уже предоставляет некоторые итераторы для многих ежедневных задач. См. список [[https://www.php.net/manual/ru/spl.iterators.php|итераторов SPL]] для более детальной информации.
====Пример====
Этот пример демонстрирует в каком порядке вызываются методы, когда используется с итератором оператор foreach.
var = $array;
}
}
public function rewind()
{
echo "перемотка в начало\n";
reset($this->var);
}
public function current()
{
$var = current($this->var);
echo "текущий: $var\n";
return $var;
}
public function key()
{
$var = key($this->var);
echo "ключ: $var\n";
return $var;
}
public function next()
{
$var = next($this->var);
echo "следующий: $var\n";
return $var;
}
public function valid()
{
$key = key($this->var);
$var = ($key !== NULL && $key !== FALSE);
echo "верный: $var\n";
return $var;
}
}
$values = array(1,2,3);
$it = new MyIterator($values);
foreach ($it as $a => $b) {
print "$a: $b\n";
}
?>
Результатом выполнения данного примера будет что-то подобное:
перемотка в начало
верный: 1
текущий: 1
ключ: 0
0: 1
следующий: 2
верный: 1
текущий: 2
ключ: 1
1: 2
следующий: 3
верный: 1
текущий: 3
ключ: 2
2: 3
следующий:
верный:
====Содержание====
- Iterator::current — Возврат текущего элемента
- Iterator::key — Возврат ключа текущего элемента
- Iterator::next — Переход к следующему элементу
- Iterator::rewind — Перемотать итератор на первый элемент
- Iterator::valid — Проверяет корректность текущей позиции