一、PHP数组简介

1、PHP数组的分类

按照下标的不同分为关联数组和索引数组
①索引数组:下标从0开始依次增长
②关联数组:下标为字符串格式,每个下标字符串与数组的值一一对应,(有点像对象的键值对)

下面详细介绍下索引数组与关联数组

①、数组中可以同时存在索引数组和关联数组;
②、数组中所有的索引数组如果不加指定会去掉关联项,默认增长;关联数组不占索引位
     array(1,2,"one"=>3,4,5); //1/2/4/5的索引-->0,1,2,3
③、如果关联数组的key,是纯十进制整数数字符串,则会将此数字转为索引数组的索引值("10.0"、"08"等格式依然是关联数组,不是数字)
      array(1,2,"one"=>3,"9"=>4) 1,2,4的索引位0/1/9
④、手动指定关联数组的key,索引数组的下标,如果与前面已有的key后下标冲突,则后指定的值会覆盖前面的值
⑤、如果手动指定索引数组下标,则后续自增长下标会按照之前下标最大值,依次增长。

二、PHP数组遍历的四种方法

1、使用常规的for循环遍历

$arr = array(1,2,3,4,5,6);
$num = count($arr);
echo "数组的个数为{$num}<br/>";
for($i=0;$i<$num;$i++){
echo "{$i}==>{$arr[$i]}<br/>";
}

2、使用foreach遍历数组(foreach可以遍历任何类型的数组)

$arr = array(1,2,3,"0ne"=>7,4,5,6);
foreach($arr as $key => $item){
echo "{$key}==>{$item}<br>";
}

3、使用list、each、while()遍历数组

首先我介绍下list和each方法

①list():将数组的每一个值赋值给list函数的每一个参数。(list函数的参数必须小于等于数组的元素个数,)
  注意:list在解析数组时只解析索引数组 list可以通过空参数,选择性的解析数组的值 list($a,,$b) = $arr[1,2,3]; $a=1 $b=3

②each():用于返回数组当前指针所在位的键值对,并将指针后移一位,
  返回值,如果指针有下一位,返回一个数组。包含一个索引数组(0-键,1-值)和一个关联数组(key-键,value-值),
  如果指针没有下一位,返回false

那么如何将三者运用在一块遍历数组呢?

①each($arr)返回数组或false
②把数组或false赋值给$a;
③while判断

while(list($key,$value) = each($arr)){

        echo "{$key}==>{$value}<br>";
}
reset($arr);//重置数组
while(list($key,$value) = each($arr)){ echo "{$key}==>{$value}<br>";
}

注意:数组使用each遍历完之后,指针始终处于最会一位的下一位,即再用each,始终返回false,可以使用reset()函数重置指针

4、使用数组指针遍历

先介绍需要用到的各种方法:

①next:将数组指针后移一位,并返回后一位的值,没有返回false
②prev:将数组指针前移一位,并返回前一位的值,没有返回false
③end: 将数组指针移至最后一位,并返回最后一位的值,空数组返回false
④reset:将数组指针恢复到第一位,并返回第一位的值,空数组返回false
⑤key:返回当前指针所在位的键
⑥current:返回当前指针所在位的值

下面介绍两种方法while和do while方法:

while方法

$arr = array(1,2,3,4,5,6);
while(true){
echo key($arr);
echo "--";
echo current($arr);
echo "<br>";
if(!next($arr)){
break;
}
}

do while方法


$arr = array(1,2,3,4,5,6); 
do{
echo key($arr);
echo "--";
echo current($arr);
echo "<br>";
}while(next($arr));

PHP数组遍历详解的更多相关文章

  1. js数组方法详解

    Array对象的方法-25个 /*js数组方法详解 */ /* * 1 concat() 用于连接多个数组或者值-------------- * 2 copyWithin() 方法用于从数组的指定位置 ...

  2. JavaScript数组方法详解

    JavaScript数组方法详解 JavaScript中数组的方法种类众多,在ES3-ES7不同版本时期都有新方法:并且数组的方法还有原型方法和从object继承的方法,这里我们只介绍数组在每个版本中 ...

  3. OpenCV学习C++接口 Mat像素遍历详解

    OpenCV学习C++接口 Mat像素遍历详解

  4. 最新java数组的详解

    java中HashMap详解 http://alex09.iteye.com/blog/539545 总结: 1.就像引用类型的数组一样,当我们把 Java 对象放入数组之时,并不是真正的把 Java ...

  5. JS数组映射详解

    现在这里占个坑位,免的忘了,需要整理一下最近的内容: 1.数组映射的使用 2.微信分享功能详解 3.jq自己封装 4.HTML的富文本应用

  6. [转载]Splay Tree数组实现+详解

    变量声明:f[i]表示i的父结点,ch[i][0]表示i的左儿子,ch[i][1]表示i的右儿子,key[i]表示i的关键字(即结点i代表的那个数字),cnt[i]表示i结点的关键字出现的次数(相当于 ...

  7. js 类数组arguments详解

    arguments并不是一个真正的数组,而是一个"类似数组(array-like)"的对象: 就像下面的这段输出,就是典型的类数组对象: [, , callee: ƒ, Symbo ...

  8. JavaScript中数组对象详解

    Array对象即数组对象用于在单个变量中存储多个值,JS的数组是弱类型的,所以允许数组中含有不同类型的元素,数组元素甚至可以是对象或者其他数组. 创建数组的语法 1.Array构造器 1.var li ...

  9. JavaScript Array数组方法详解

    Array类型是ECMAScript中最常用的引用类型.ECMAScript中的数据与其它大多数语言中的数组有着相当大的区别.虽然ECMAScript中的数据与其它语言中的数组一样都是数据的有序列表, ...

随机推荐

  1. 点滴积累【JS】---JQuery实现条形统计图,适用于选择题等统计

    效果: 思路:前台JS实现动态数据效果,后台可以拼接字符串或者用JSON加载数据 代码: <%@ Page Language="C#" AutoEventWireup=&qu ...

  2. Java Web框架play framework的下载与环境变量配置

    Web项目的开发有着众多的框架,近期刚刚接触了play. 对于一个Java开发者来说,play是一个不可多得的好框架.以下我简介下怎样下载play .以及play的环境变量配置方法. (1)登录pla ...

  3. vim编码设置

    转载于:http://www.cnblogs.com/freewater/archive/2011/08/26/2154602.html vim 编码方式的设置和所有的流行文本编辑器一样,Vim 可以 ...

  4. Ubuntu下修改tomcat6默认的8080端口

    $ sudo vi /etc/tomcat6/server.xml   将 <Connector port="8080" protocol="HTTP/1.1&qu ...

  5. CSS border-style 属性查询

    border-style 属性用于设置元素所有边框的样式,或者单独地为各边设置边框样式.只有当这个值不是 none 时边框才可能出现. none solid dotted dashed double ...

  6. ubus

    openwrt提供了一个系统总线ubus,类似linux桌面操作系统的d-bus,目标是提供系统级的进程间通信(IPC)功能. 为了提供各种后台进程和应用程序之间的通信机制,ubus被开发出来,由3部 ...

  7. [转]Mac系统安装软件提示软件已损坏的解决办法

    很多朋友下载本站提供的Mac软件资源,安装提示“xxx软件已损坏,打不开,您应该将它移到废纸篓”的提示,其实并不是软件本身有问题,而是Mac系统的一个安全机制问题,按照如下方法操作,即可打开并安装本站 ...

  8. 请写出JavaScript中常用的三种事件。

    请写出JavaScript中常用的三种事件. 解答: onclick,onblur,onChange

  9. 嵌入式驱动开发之phy---fine Mac与Phy组成原理的简单分析

    关键字rj45.pci-e 1. general 下图是网口结构简图.网口由CPU.MAC和PHY三部分组成.DMA控制器通常属于CPU的一部分,用虚线放在这里是为了表示DMA控制器可能会参与到网口数 ...

  10. CSS径向渐变radial-gradient

    可以做一些效果,不错! 网址:http://www.cnblogs.com/xiaohuochai/p/5383285.html