= 4.0.6, PHP 5, PHP 7, PHP 8)array_map — 為數(shù)組的每個元素應(yīng)用回調(diào)函數(shù) 說明array_map(?callable $callback, array $array, array ...$arrays): arrayarray_">
(PHP 4 >= 4.0.6, PHP 5, PHP 7, PHP 8)
array_map — 為數(shù)組的每個元素應(yīng)用回調(diào)函數(shù)
array_map() 返回一個 array,內(nèi)容為 array
的元素按相應(yīng)的順序調(diào)用
callback
后的結(jié)果(如果提供了更多數(shù)組,還會利用 arrays
傳入)。callback
函數(shù)形參的數(shù)量必須匹配 array_map()
實參中數(shù)組的數(shù)量。多余的實參數(shù)組將會被忽略。如果提供的實參數(shù)組的數(shù)量不足,將拋出 ArgumentCountError。
callback
回調(diào)函數(shù) callable,應(yīng)用到每個數(shù)組里的每個元素。
多個數(shù)組操作合并時,callback
可以設(shè)置為 null
。
如果只提供了 array
一個數(shù)組,
array_map() 會返回輸入的數(shù)組。
array
數(shù)組,遍歷運(yùn)行 callback
函數(shù)。
arrays
額外的數(shù)組列表,每個都遍歷運(yùn)行 callback
函數(shù)。
返回數(shù)組,包含 callback
函數(shù)處理之后 array
(有多個數(shù)組時,為 arrays
) 對應(yīng)索引所有元素作為函數(shù)的參數(shù)。
當(dāng)僅僅傳入一個數(shù)組時,返回的數(shù)組會保留傳入?yún)?shù)的鍵(key)。 傳入多個數(shù)組時,返回的數(shù)組鍵是按順序的 integer。
版本 | 說明 |
---|---|
8.0.0 |
如果 callback 接受引用傳遞參數(shù),該方法將會拋出
E_WARNING 。
|
示例 #1 array_map() 例子
<?php
function cube($n)
{
return ($n * $n * $n);
}
$a = [1, 2, 3, 4, 5];
$b = array_map('cube', $a);
print_r($b);
?>
這使得 $b 成為:
Array ( [0] => 1 [1] => 8 [2] => 27 [3] => 64 [4] => 125 )
示例 #2 array_map() 使用匿名函數(shù)
<?php
$func = function(int $value): int {
return $value * 2;
};
print_r(array_map($func, range(1, 5)));
// 或者從 PHP 7.4.0 起:
print_r(array_map(fn($value): int => $value * 2, range(1, 5)));
?>
Array ( [0] => 2 [1] => 4 [2] => 6 [3] => 8 [4] => 10 )
示例 #3 array_map():使用更多的數(shù)組
<?php
function show_Spanish(int $n, string $m): string
{
return "The number {$n} is called {$m} in Spanish";
}
function map_Spanish(int $n, string $m): array
{
return [$n => $m];
}
$a = [1, 2, 3, 4, 5];
$b = ['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);
?>
以上例程會輸出:
// 打印 $c Array ( [0] => The number 1 is called uno in Spanish [1] => The number 2 is called dos in Spanish [2] => The number 3 is called tres in Spanish [3] => The number 4 is called cuatro in Spanish [4] => The number 5 is called cinco in Spanish ) // 打印 $d Array ( [0] => Array ( [1] => uno ) [1] => Array ( [2] => dos ) [2] => Array ( [3] => tres ) [3] => Array ( [4] => cuatro ) [4] => Array ( [5] => cinco ) )
傳入兩個及以上的數(shù)組時,它們元素數(shù)量將會相同。因為回調(diào)函數(shù)會并行地處理相互對應(yīng)的元素。 如果幾個數(shù)組的元素數(shù)量不一致:空元素會擴(kuò)展短那個數(shù)組,直到長度和最長的數(shù)組一樣。
此函數(shù)有個有趣的用法:傳入 null
作為回調(diào)函數(shù)的名稱,將創(chuàng)建多維數(shù)組(一個數(shù)組,內(nèi)部包含數(shù)組。)
示例 #4 多個數(shù)組的合并操作
<?php
$a = [1, 2, 3, 4, 5];
$b = ['one', 'two', 'three', 'four', 'five'];
$c = ['uno', 'dos', 'tres', 'cuatro', 'cinco'];
$d = array_map(null, $a, $b, $c);
print_r($d);
?>
以上例程會輸出:
Array ( [0] => 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 ) )
示例 #5
僅有 array1
時,callback
設(shè)置為 null
<?php
$array = [1, 2, 3];
var_dump(array_map(null, $array));
?>
以上例程會輸出:
array(3) { [0]=> int(1) [1]=> int(2) [2]=> int(3) }
示例 #6 array_map() 鍵(key)是 string
<?php
$arr = array("stringkey" => "value");
function cb1($a) {
return [$a];
}
function cb2($a, $b) {
return [$a, $b];
}
var_dump(array_map('cb1', $arr));
var_dump(array_map('cb2', $arr, $arr));
var_dump(array_map(null, $arr));
var_dump(array_map(null, $arr, $arr));
?>
以上例程會輸出:
array(1) { ["stringkey"]=> array(1) { [0]=> string(5) "value" } } array(1) { [0]=> array(2) { [0]=> string(5) "value" [1]=> string(5) "value" } } array(1) { ["stringkey"]=> string(5) "value" } array(1) { [0]=> array(2) { [0]=> string(5) "value" [1]=> string(5) "value" } }
示例 #7 array_map() - 關(guān)聯(lián)數(shù)組
雖然 array_map() 不能直接支持使用數(shù)組的鍵(key)作為輸入,但可以使用 array_keys() 進(jìn)行模擬。
<?php
$arr = [
'v1' => 'First release',
'v2' => 'Second release',
'v3' => 'Third release',
];
// 注意: 在 7.4.0 之前,使用較長的語法來代替匿名函數(shù)。
$callback = fn(string $k, string $v): string => "$k was the $v";
$result = array_map($callback, array_keys($arr), array_values($arr));
var_dump($result);
?>
以上例程會輸出:
array(3) { [0]=> string(24) "v1 was the First release" [1]=> string(25) "v2 was the Second release" [2]=> string(24) "v3 was the Third release" }