array_map
Применить функцию обратного вызова ко всем элементам указанных массивов
Описание
массивarray_map
смешанноефункция
массивмассив_1
массивмассив_2...
Функция array_map возвращает массив, содержащий
элементы всех указанных массивов после их обработки функцией обратного
вызова. Количество параметров, передаваемых функции обратного
вызова, должно совпадать с количеством массивов, переданным
функции array_map.
Пример использования array_map
В результате переменная $b будет содержать:
1
[1] => 8
[2] => 27
[3] => 64
[4] => 125
)
]]>
Пример использования array_map: обработка нескольких массивов
$m);
}
$a = array(1, 2, 3, 4, 5);
$b = array("uno", "dos", "tres", "cuatro", "cinco");
$c = array_map("show_Spanish", $a, $b);
print_r($c);
$d = array_map("map_Spanish", $a , $b);
print_r($d);
]]>
Результат выполнения:
Число 1 по-испански - uno
[1] => Число 2 по-испански - dos
[2] => Число 3 по-испански - tres
[3] => Число 4 по-испански - cuatro
[4] => Число 5 по-испански - cinco
)
// printout of $d
Array
(
[0] => Array
(
[1] => uno
)
[1] => Array
(
[2] => dos
)
[2] => Array
(
[3] => tres
)
[3] => Array
(
[4] => cuatro
)
[4] => Array
(
[5] => cinco
)
)
]]>
Обычно при обработке двух или более массивов, они имею одинаковую длину,
так как функция обратного вызова применяется параллельно к соответствующим
элементам массивов. Если массивы имеют различную длину, самый маленький
из них дополняется элементами с пустыми значениями.
Интересным эффектом при использовании этой функции является создание
массива массивов, что может быть достигнуто путем использования
значения &null; в качестве имени функции обратного вызова.
Создание массива массивов
Результатом выполнения вышеприведенной программы будет:
Array
(
[0] => 1
[1] => one
[2] => uno
)
[1] => Array
(
[0] => 2
[1] => two
[2] => dos
)
[2] => Array
(
[0] => 3
[1] => three
[2] => tres
)
[3] => Array
(
[0] => 4
[1] => four
[2] => cuatro
)
[4] => Array
(
[0] => 5
[1] => five
[2] => cinco
)
)
]]>
См.также array_filter и array_reduce.