array_map()的函数原型为:array array_map ( callback callback, array arr1 [, array ...] )
array_map() 返回一个数组,该数组包含了arr1中的所有单元经过callback作用过之后的单元。callback接受的参数数目应该和传递给 array_map() 函数的数组数目一致。
callback函数就是array_map所将调用来处理元素单元函数,应以字符串的形式将函数名传递给array_map()
如:(php官方手册所给出的代码)
<?php
function cube($n)
{
return($n * $n * $n);
}
$a = array(1, 2, 3, 4, 5);
$b = array_map("cube", $a);
print_r($b);
?>
cube即为callback函数 ,且array_map的callback函数的参数每一个应均为数组的元素,也就是array_map()除了第一个参数外,其余参数应均为数组且应与回调函数的参数个数一样.
<?php //callback 1 function check($n) { //array_mapcallback的参数为数组的元素, //也就是callback中有几个参数array_map就应传入几个数组 if($n>100) { return $n-10; }else { return $n; } } //callback 2 function add($a,$b) { return $a+$b; } $arr = array(101,85,35,105,99,109);// var_dump($arr); $brr = array(1,2,3,4,5,6); $arr = array_map("check", $arr); $brr = array_map("add", $arr,$brr); print_r($arr); echo "<br/>"; print_r($brr); ?>
输出结果
array (size=6) 0 => int 101 1 => int 85 2 => int 35 3 => int 105 4 => int 99 5 => int 109
Array ( [0] => 91 [1] => 85 [2] => 35 [3] => 95 [4] => 99 [5] => 99 )
Array ( [0] => 92 [1] => 87 [2] => 38 [3] => 99 [4] => 104 [5] => 105 )
========================================================================================
我是分割线
========================================================================================
与array_map()不同array_walk()的返回值是布尔型,也就是如果想要修改数组的数据,应该在callback函数上做手脚(也就是引用)
array_walk()会将数组的元素的值,以及键值传递给callback函数,此外还允许传递其类型的数据给callback函数.
以下为其原型以及官方文档:
bool array_walk ( array &array, callback funcname [, mixed userdata] )
如果成功则返回 TRUE,失败则返回 FALSE。
将用户自定义函数funcname应用到array数组中的每个单元。典型情况下funcname接受两个参数。array参数的值作为第一个,键名作为第二个。如果提供了可选参数userdata,将被作为第三个参数传递给 callbackfuncname。
如果funcname函数需要的参数比给出的多,则每次 array_walk() 调用funcname时都会产生一个 E_WARNING 级的错误。这些警告可以通过在 array_walk() 调用前加上 PHP 的错误操作符 @ 来抑制,或者用 error_reporting()。
注: 如果funcname需要直接作用于数组中的值,则给funcname的第一个参数指定为引用。这样任何对这些单元的改变也将会改变原始数组本身。
注: 将键名和 userdata 传递到funcname中是 PHP 4.0 新增加的。
array_walk() 不会受到array内部数组指针的影响。array_walk() 会遍历整个数组而不管指针的位置。
用户不应在回调函数中改变该数组本身。例如增加/删除单元,unset 单元等等。如果 array_walk() 作用的数组改变了,则此函数的的行为未经定义,且不可预期。
以下是我自己写的一个简单的例子:
<?php function alter(&$value,$key,$userdata) { //在此处不对元素值做任何修改,如果想要修改则需像我一样给参数加上引用 echo $key.$userdata.$value.'<br/>'; } $arr = array("a"=>"A","b"=>"B","c"=>"C","d"=>"D"); //array_walk -- 对数组中的每个成员应用用户函数 //函数原型:bool array_walk ( array &array, callback funcname [, mixed userdata] ) //第一个参数为 数组 //第二个参数为 callback函数名, //第三个参数为 可选参数(将传递给所callback的函数) //============================================================================== //array_map()将传递callback 函数的 的 //第一个参数是元素的值,如需修改则应加上 &操作符 //第二个参数为键值,如需修改则作如上处理 //第三个参数为用户自己传递给函数的数据(即array_walk()中的第三个参数) array_walk($arr,'alter',".is."); ?>
输出
a.is.A
b.is.B
c.is.C
d.is.D
----------------------------------------------------------------------------------------
----------------------------------------------------------------------------------------