【php学习】array_map,array_walk,array_filter的区别
array_map(function($v){
//
}, $array);
array_walk($array, function($v, $k){
//
});
array_filter($array, function($v){
//
});
以上三者 array_map、array_walk、array_filter
相同点:都是利用回调函数对数组中每个元素进行操作。
不同点:
- 返回值
- 回调函数的参数
- 是否改变数组的值
array_map 返回的是新数组,原数组不变(新数组和原数组的数组长度应该一样)。
array_walk 返回的布尔值,如果要改变数组元素的值,回调函数第一个参数必须是引用,如 array_walk($array, function(&$v, $k){}); , arrary_walk 的回调函数还能够接收数组的key。
array_filter 返回的是新数组,原数组不变。它的作用是过滤数组中的元素。回调函数返回真,元素才能保存到新数组中,即(新数组和原数组的数组长度可能不一样)
下面是个例子
echo "<pre>";
testArrayCallBack();
function testArrayCallBack(){
$arr = array(12,64,3,47); //array_map返回的新数组,原数组不变
$newArr = array_map(function($v){
return ++$v;
},$arr);
echo "原数组:<br/>"; print_r($arr);
echo "array_map 返回的新数组:<br/>"; print_r($newArr); //array_walk返回布尔值,原数组改变
$b = array_walk($arr, function(&$v, $k){ //如果想回调函数能直接改变数组的值,那么回调函数地址参数应为引用。
$v+=$k;
});
echo "原数组:<br/>"; print_r($arr);
echo "array_walk 返回的布尔值:"; var_dump($b ); //array_filter返回新数组,原数组不变
$newArr = array_filter($arr, function($v){
return $v > 10;
});
echo "原数组:<br/>"; print_r($arr);
echo "array_filter返回的新数组:<br/>"; print_r($newArr);
}
执行结果:
原数组:
Array
(
[0] => 12
[1] => 64
[2] => 3
[3] => 47
)
array_map 返回的新数组:
Array
(
[0] => 13
[1] => 65
[2] => 4
[3] => 48
)
原数组:
Array
(
[0] => 12
[1] => 65
[2] => 5
[3] => 50
)
array_walk 返回的布尔值:bool(true)
原数组:
Array
(
[0] => 12
[1] => 65
[2] => 5
[3] => 50
)
array_filter返回的新数组:
Array
(
[0] => 12
[1] => 65
[3] => 50
)
总结:
array_map 对参数数组的每个元素进行操作,返回新数组,不改变原数组的值
array_walk 对参数数组的每个元素进行操作,返回布尔,改变原数组的值。
array_filter 对参数数组的元素进行过滤,返回新数组,不改变原数组的值。
【php学习】array_map,array_walk,array_filter的区别的更多相关文章
- array_walk、array_map、array_filter 的用法
array_walk.array_map.array_filter 和 foreach 都有循环对数组元素进行处理的功能. 一.array_walk 用法 1.循环数组,回调处理(并不修改数组元素的 ...
- 空循环比较 for foreach array_map array_walk
申请一个数组,然后不断的跑空循环,看看执行时间 for循环 foreach (不使用键) foreach(使用键) array_map array_walk 查看效率速度发现很明显 是foreach更 ...
- 009——数组(九) each list array_map array_walk array_walk_recursive
<?php /** * 9 数组 each list array_map array_walk array_walk_recursive */ //each() 返回数组中的键名和键值生成新数组 ...
- mybatis学习$与#号取值区别
1,多个参数传递用map或实体封装后再传给myBatis, mybatis学习$与#号取值区别 #{} 1.加了单引号, 2.#号写是可以防止sql注入,比较安全 select * from use ...
- php中array_walk() 和 array_map()两个函数区别
两个函数的共性和区别: 1.传入这两个函数的 $value,就是数组中的单一个元素. 2.array_walk() 仅返回true或者false,array_map() 返回处理后的数组: 3.要得到 ...
- array_map array_walk
$config = [ => [], => [], => [] ]; array_map(function($key) use ($config){ print_r($key); d ...
- 深度学习VS机器学习——到底什么区别
转自:https://baijiahao.baidu.com/s?id=1595509949786067084&wfr=spider&for=pc 最近在听深度学习的课,老师提了一个基 ...
- Maven学习----dependencies与dependencyManagement的区别(转)
转自:http://blog.csdn.net/liutengteng130/article/details/46991829 1.DepencyManagement应用场景 当我们的项目模块很多的时 ...
- UNITY3D单词学习 speed和velocity的区别
在日常用语中,这两个词没有区别,可以通用. 而在物理学里,velocity 是一个矢量(vector quantity)表示起点与终点间直线距离的长度除以所用时间所得的量,并注明方向;而 speed ...
随机推荐
- Chromium Embedded Framework 中文文档(简介)
转自:http://www.cnblogs.com/think/archive/2011/10/06/CEF-Introduce.html 简介 Chromium Embedded Framework ...
- 计算字符串相似度算法——Levenshtein
转自:http://wdhdmx.iteye.com/blog/1343856 0.这个算法实现起来很简单 1.百度百科介绍: Levenshtein 距离,又称编辑距离,指的是两个字符串之间,由一个 ...
- Z-XML团队 软件工程课之我感我思我收获
<软件工程>这门课像我们的诤友,不断督促我们前进,又不断指引我们收获.时间飞逝,我们Z-XML团队一个个完成了课程中的所有任务,一步步走到了期末年末. 走的远了,也该回头看看.全员7人回顾 ...
- loj 1063(求割点个数)
题目链接:http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=26780 思路:判断一个点是否是割点的两个条件:1.如果一个点v是根 ...
- PHP扩展开发
安装好php,进入安装目录. zbseoag@ubuntu:/usr/local/php-5.6.28/ext$ ./ext_skel --extname=mytest zbseoag@ubuntu: ...
- 版本引发的血案check the manual that corresponds to your MySQL server version for the right syntax
该错误mysql5.1有问题,mysql5.3版本没问题
- Linux常用命令_(网络管理)
网络信息:hostname.netstat.route.ifconfig网络配置:netconfig网络测试:ping hostname–查看主机名称ifconfig–查看和设置网络配置–ifconf ...
- maven 编译报错 “找不到符号”
报错如下: E:\workspace\iccardcore\mis\src\main\java\com\hxsmart\sicard\core\webapp\action\process\DayEnd ...
- 最短路(Floyd_Warshall) POJ 2240 Arbitrage
题目传送门 /* 最短路:Floyd模板题 只要把+改为*就ok了,热闹后判断d[i][i]是否大于1 文件输入的ONLINE_JUDGE少写了个_,WA了N遍:) */ #include <c ...
- [BZOJ 3759]Hungergame
Nim游戏获胜的条件是所有石子的异或和为0 如果先手要获胜,那么一定是打开了一个异或和为0的极大子集 什么是极大子集呢? 就是无论后手打开任何子集的箱子,都不能再使此时打开的箱子异或和为0. 容易证明 ...