Iterables
Iterable is a pseudo-type introduced in PHP 7.1. It accepts any array or object implementing the Traversable interface. Both of these types are iterable using foreach and can be used with yield from within a generator.
Using Iterables
Iterable can be used as a parameter type to indicate that a function requires a set of values, but does not care about the form of the value set since it will be used with foreach. If a value is not an array or instance of Traversable, a TypeError will be thrown.
Example #1 Iterable parameter type example
<?php
function foo(iterable $iterable) {
foreach ($iterable as $value) {
// ...
}
}
?>
Parameters declared as iterable may use null
or an array as a default
value.
Example #2 Iterable parameter default value example
<?php
function foo(iterable $iterable = []) {
// ...
}
?>
Iterable can also be used as a return type to indicate a function will return an iterable value. If the returned value is not an array or instance of Traversable, a TypeError will be thrown.
Example #3 Iterable return type example
<?php
function bar(): iterable {
return [1, 2, 3];
}
?>
Functions declaring iterable as a return type may also be generators.
Example #4 Iterable generator return type example
<?php
function gen(): iterable {
yield 1;
yield 2;
yield 3;
}
?>