<?php
/**
* 9 数组 each list array_map array_walk array_walk_recursive
*/ //each() 返回数组中的键名和键值生成新数组,如果指针结束,返回布尔值false
/*
$array1=array('webname'=>"博客",'weburl'=>"bbs.blog.com");
$array_new=each($array1); //生成新的数组:
print_r($array_new);
//输出:Array ( [1] => 博客 [value] => 博客 [0] => webname [key] => webname )
$array_new=each($array1); //生成新的数组:
print_r($array_new);
//输出:Array ( [1] => bbs.blog.com [value] => bbs.blog.com [0] => weburl [key] => weburl )
*/ //list() 将索引数组的值,赋给变量
/*$array1=array("博客","bbs.blog.com");
list($value)=$array1;
echo $value;//输出:博客*/ /*$array1=array('webname'=>"博客",'weburl'=>"bbs.blog.com");
while (list($k,$v)=each($array1)){
echo "键名:".$k."=>"."键值".$v;
}//输出:键名:webname=>键值博客键名:weburl=>键值bbs.blog.com*/ //array_map() 数组的每一个元素应用,都经过回调函数处理,返回值是处理过的元素组成的新数组
/*$blog=array(11,22,33,440,55,660);
function func_map($v){
echo $v; //输出:11223344055660
}
$array_new=array_map('func_map',$blog);*/ /*$blog=array(11,22,33,440,55,660);
function func_map($v){
if ($v>100){
return $v;
}
}
$array_new=array_map('func_map',$blog);
print_r($array_new);//输出:Array ( [0] => [1] => [2] => [3] => 440 [4] => [5] => 660 )*/ /*$blog=array(11,22,33,440,55,660);
function func_map($v){
return $v+10;
}
$array_new=array_map('func_map',$blog);
print_r($array_new);//输出:Array ( [0] => 21 [1] => 32 [2] => 43 [3] => 450 [4] => 65 [5] => 670 )*/ /*$arr1=array(1,2,3,4,5);
$arr2=array("a","b","c","d","e");
function func4($arr1,$arr2){
//echo $arr1;//输出:12345
return array($arr2=>$arr1);
} $arr0=array_map(func4,$arr1,$arr2);
print_r($arr0);
//输出:Array ( [0] => Array ( [a] => 1 ) [1] => Array ( [b] => 2 ) [2] => Array ( [c] => 3 ) [3] => Array ( [d] => 4 ) [4] => Array ( [e] => 5 ) )*/ //array_walk() 数组中的每一个元素,应用回调函数,成功返回true,失败返回false
/*$array1=array('张三'=>1000,'李四'=>900,'王五'=>3000,'赵六'=>400);
function func_walk(&$v,$k){
if ($v<1000){
$v+=500;
}
}
if (array_walk($array1,func_walk)){
echo "加工资成功:";
print_r($array1);
//输出:加工资成功:Array ( [张三] => 1000 [李四] => 1400 [王五] => 3000 [赵六] => 900 )
}*/ /*$array1=array('张三'=>1000,'李四'=>900,'王五'=>3000,'赵六'=>400);
function func_walk(&$v,$k,$c=""){
if ($v<1000){
$v+=$c;
}
}
if (array_walk($array1,func_walk,1000)){
echo "加工资成功:";
print_r($array1);
//输出:加工资成功:Array ( [张三] => 1000 [李四] => 1900 [王五] => 3000 [赵六] => 1400 )
}*/ //array_walk_recursive() 递归的操作数组,使数组中的元素应用回调函数
$arr5 = array(
array('uname' => '李四', 'money' => 100),
array('uname' => '张三', 'money' => 600),
array('uname' => '王五', 'money' => 700),
array('uname' => '赵六', 'money' => 300)
); function fun5(&$v,$k){
//echo $v; //输出:李四500张三600王五700赵六800
if ($k=='money' && $v<300){
$v+=1000;
}
}
array_walk_recursive($arr5,'fun5');
print_r($arr5);//输出:Array ( [0] => Array ( [uname] => 李四 [money] => 1100 ) [1] => Array ( [uname] => 张三 [money] => 600 ) [2] => Array ( [uname] => 王五 [money] => 700 ) [3] => Array ( [uname] => 赵六 [money] => 300 ) )

  

009——数组(九) each list array_map array_walk array_walk_recursive的更多相关文章

  1. 空循环比较 for foreach array_map array_walk

    申请一个数组,然后不断的跑空循环,看看执行时间 for循环 foreach (不使用键) foreach(使用键) array_map array_walk 查看效率速度发现很明显 是foreach更 ...

  2. 将对象转为数组方法:延伸array_map函数在PHP类中调用内部方法

    public static function objectToArray($d) { if (is_object($d)) { $d = get_object_vars($d); } if (is_a ...

  3. array_map array_walk

    $config = [ => [], => [], => [] ]; array_map(function($key) use ($config){ print_r($key); d ...

  4. php中多图上传采用数组差集处理(array_diff,array_map)

    //删除旧有的图片 //新增数组 $arr2=array(); //原有数组 $old_pics = ReportPic::find()->where(['report_id' => $i ...

  5. 浅析 array_map array_walk

    map    主要是为了得到你的回调函数处理后的新数组,要的是结果. walk   主要是对每个参数都使用一次你的回调函数,要的是处理的过程. walk   可以认为提供额外参数给回调函数,map不可 ...

  6. array_filter、array_map、array_walk解释

    /** * array_filter 用回调函数处理数组中的各个元素, * 重点在于过滤(而不是新增)某个元素,当你处理到一个元素时, * 如果返回了false,那么这个元素将会被过滤掉.PS:保持了 ...

  7. 【php学习】array_map,array_walk,array_filter的区别

    array_map(function($v){return $v+1;}, $array); array_walk($array, function($v, $k){...}); array_filt ...

  8. 【转】php 之 array_filter、array_walk、array_map的区别

    [转]php 之 array_filter.array_walk.array_map的区别 原文:https://blog.csdn.net/csdnzhangyiwei/article/detail ...

  9. array_map、array_walk、array_filter三个函数的区别

    array_walk --- 使自定的函数能处理数组的每个元素 bool array_walk ( array &array, callback funcname [, mixed userd ...

随机推荐

  1. Java程序运行在Docker等容器环境有哪些新问题

    基本回答 一.  对于Java来说,Docker毕竟是一个较新的环境,其内存.CPU等资源限制是通过ControlGroup实现的.早期的JDK版本并不能识别这些限制,进而会导致一些基础问题. 1.如 ...

  2. SpringMVC整合ActiveMQ

    spring activeMq 配置 <!-- ActiveMQ 连接工厂 --> <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服 ...

  3. char,short,int长度

    数据类型的本质就是固定内存大小的别名 char:1byte short:  2byte int:4byte 其实变量也是对连续内存的别名,相当于这段内存的句柄.钩子

  4. JavaScript的this指针到底指向哪?

    编程过程中,着实十分困扰this的指向性,经过查阅一番资料,终于搞清楚了,在这里总结一下,全文分为以下三个部分: 什么是this指针? this指针指向哪里? 何时使用this? 一 什么是this指 ...

  5. jz2440使用openjtag+openocd+eclipse调试【学习笔记】

    平台:jz2440 作者:庄泽彬(欢迎转载,请注明作者) 说明:韦东山二期视频学习笔记 交叉编译工具:arm-linux-gcc (GCC) 3.4.5 eclipse版本:eclipse-cpp-l ...

  6. [BZOJ1026]windy数

    Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道,在A和B之间,包括A和B,总共有多少个windy数? In ...

  7. 翻翻git之---丰富多样的路由跳转开源库 ARouter

    转载请注明出处:王亟亟的大牛之路 有一段时间没更新博客了,最近也没学什么新东西,正好组里小伙在做路由跳转的一个"公共库",然后正好最近这样的轮子不少,我也就跟着看看,学习一下人家的 ...

  8. centos7配置安装redis

    关闭防火墙:systemctl stop firewalld.service #停止firewallsystemctl disable firewalld.service #禁止firewall开机启 ...

  9. LCS最长共同子序列

    2017-09-02 15:06:57 writer:pprp 状态表示: f(n,m)表示s1[0..n]和s2[0..m]从0开始计数,最终结果是f(N-1,M-1)考虑四种情况: 1/ s1[n ...

  10. java将配置信息写在数据库(利用反射)

    Demo出处: 1. package com.fpx.pcs.prealert.process.xml.service.impl; public class CainiaoPushMessageSer ...