一、数组的概述
* 1. 数组的本质:管理和操作一组变量,成批处理
* 2. 数组是复合类型
* 3. 数组中可以存储任意长度的数据,也可以存储任意类型的数据
* 4. 数组就可以完成其它语言数据结构的功能(链表, 队列, 栈, 集合类)
*
* 二、数组的分类
* 数组中存有多个单元,(单元称为元素)
* 每个元素(下标[键]和值)
* 单访问元素时候,都是通过下标(键)来访问元素
*
* 1. 一维数组, 二维数组, 三维数组 。。。 多维数组
* (数组的数组, 就是在数组中存有其它的数组)
* 2. PHP中有两种数组
* 索引数组:就是下标是顺序整数作为索引
* 关联数组:就是下标是字符串作为索引
*
* 下标(整数, 字符串)只有这两种
*
* 三、数组多种声明方式
* 1. 直接为数组元素赋值
  a.如果索引下标不给出,就会从0开始顺序索引
  b.如果给出索引下标,下一个就会是从最大的开始增1
  c.如果后面出现前面的下标,如果是赋值就是为前面的元素重新赋值
  d. 混合声明时,索引和关联不互相影响(不影响索引下标的声明)
* 2. 使用array()函数
  a. 默认是索引数组
  b.如果为关联数组和索引数组指定下标,使用 键=>值
  c.多个成员之前使用“,”分割
 3. 使用其它的函数声明
* file();

四、 数组的遍历
*
 1. 使用for语句循环遍历数组
   a. 其它语言(只有这一种方式)
  b. PHP中这种方式不是我们首选方式
  c. 数组必须是索引数组,而且下标还必须是连续的
  (索引数组下标还可以不连序,数组还有关联数组)

 2. 使用foreach语句循环遍历数组
   foreach(数组变量 as 变量值){
      //循环体
   }
   a. 循环次数由数组的元素个数决定
   b. 每一次循环都会将数组中的元素分别赋值给后面变量
  
  foreach(数组变量 as 下标变量=> 值变量){
  
   }
例子:

 1 <?php
2 $info=array(
3 "user"=>array(
4 //$user[0]
5 array(1, "zansan", 10, "nan"),
6 //$user[1][1]
7 array(2, "lisi", 20, "nv"), //$user[1]
8 //$user[2]
9 array(3, "wangwu", 30, "nan")
10 ),
11 "score"=>array(
12 array(1, 100, 90, 80),
13 array(2, 99, 88, 11),
14 array(3, 10, 50, 88)
15 ),
16 "connect"=>array(
17 array(1, '110', 'aaa@bbb.com'),
18 array(2, '120', 'bbb@ccc.com'),
19 array(3, '119', 'ccc@ddd.com')
20 )
21 );
22
23
24 foreach($info as $tablename=>$table){
25 echo '<table align="center" width="500" border="1">';
26 echo '<caption><h1>'.$tablename.'</h1></caption>';
27 foreach($table as $row){
28 echo '<tr>';
29 foreach($row as $col){
30 echo '<td>'.$col.'</td>';
31 }
32 echo '</tr>';
33 }
34 echo '</table>';
35 }

3. while() list() each() 组合循环遍历数组
*
* each()函数,
  a. 需要一个数组作为参数
  b. 返回来的也是一个数组
  c. 返回来的数组是0, 1, key, value四个下标(固定的)
    0和key下标是当前参数数组元素的鍵
    1和value下标是当前数组元素的值
  d. 默认认当前元素就是第一个元素
  e. 每执行一次后就会将当前元素向后移动
  f. 如果到最后的元素再执行这个函数,则返回false
*
* //Array ( [1] => 1 [value] => 1 [0] => id [key] => id )
*

$user=array("id"=>1, "name"=>"zhangsan", "age"=>10, "sex"=>"nan");

while($arr=each($user)){
//echo $arr[0]."==>".$arr[1]."<br>";
echo $arr["key"]."---->".$arr["value"]."<br>";
}

* list()函数
   a. list()=array(); 需要将一个数组赋值给这个函数
  b. 数组中的元素个数,要和list()函数中的参数个数相同
   c. 数组中的每个元素值会赋值list()函数中的每个参数,list()将每个参数转为变量
  d. list()只能接收索引数组
  e. 按索引的下标的顺序

list($name, $age, $sex)=array("zansan", 10, "nnnnn");

echo $name."<br>";
echo $age."<br>";
echo $sex."<br>"; list($name, , $sex)=array("zansan", 10, "nnnnn"); echo $name."<br>"; echo $sex."<br>"; $ip="192.168.1.128"; list(, , , $d)=explode(".", $ip); echo $d; $user=array("id"=>1, "name"=>"zhangsan", "age"=>10, "sex"=>"nan"); while($arr=each($user)){
//echo $arr[0]."==>".$arr[1]."<br>";
echo $arr["key"]."---->".$arr["value"]."<br>";
} $user=array("id"=>1, "name"=>"zhangsan", "age"=>10, "sex"=>"nan"); while(list($key, $value)=each($user)){
echo $key."==>".$value."<br>";
}

使用数组的内部指针控制函数
  next(数组);
  prev(数组);
  reset(数组)
  end(数组);

  current(数组);

  key(数组);

$user=array("id"=>1, "name"=>"zhangsan", "age"=>10, "sex"=>"nan");

    while(list($key, $value)=each($user)){
echo $key."==>".$value."<br>";
}
reset($user);
while(list($key, $value)=each($user)){
echo $key."==>".$value."<br>";
}
reset($user);
next($user);
next($user);
while(list($key, $value)=each($user)){
echo $key."==>".$value."<br>";
}
reset($user); echo current($user)."===========>".key($user)."<br>";
end($user);
echo current($user)."===========>".key($user)."<br>";
prev($user);
echo current($user)."===========>".key($user)."<br>";

PHP基础-数组的更多相关文章

  1. 【搬砖】安卓入门(4)- Java开发编程基础--数组

    05.01_Java语言基础(数组概述和定义格式说明)(了解) A:为什么要有数组(容器) 为了存储同种数据类型的多个值 B:数组概念 数组是存储同一种数据类型多个元素的集合.也可以看成是一个容器. ...

  2. PHP基础 数组函数 的总结

    <?php /** * PHP基础 数组操作函数 * * 指针函数:[类似于数据库的游标] 见例1.1 * current($arr)/pos 返回当前指针指向的元素 * key($arr) 返 ...

  3. Java基础——数组应用之StringBuilder类和StringBuffer类

    接上文:Java基础——数组应用之字符串String类 一.StringBuffer类 StringBuffer类和String一样,也用来代表字符串,只是由于StringBuffer的内部实现方式和 ...

  4. java基础-数组的折半查找原理

    java基础-数组的折半查找原理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 如果让你写一个数组的查找功能,需求如下:在一个数组中,找一个元素,是否存在于数组中, 如果存在就返回 ...

  5. Java基础-数组常见排序方式

    Java基础-数组常见排序方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 数据的排序一般都是生序排序,即元素从小到大排列.常见的有两种排序方式:选择排序和冒泡排序.选择排序的特 ...

  6. day05<Java语言基础--数组>

    Java语言基础(数组概述和定义格式说明) Java语言基础(数组的初始化动态初始化) Java语言基础(Java中的内存分配以及栈和堆的区别) Java语言基础(数组的内存图解1一个数组) Java ...

  7. Java语言基础(数组)

    Java语言基础(数组概述和定义格式说明) A:为什么要有数组(容器) 为了存储同种数据类型的多个值 B:数组概念 数组是存储同一种数据类型多个元素的集合.也可以看成是一个容器. 数组既可以存储基本数 ...

  8. 算法与数据结构基础 - 数组(Array)

    数组基础 数组是最基础的数据结构,特点是O(1)时间读取任意下标元素,经常应用于排序(Sort).双指针(Two Pointers).二分查找(Binary Search).动态规划(DP)等算法.顺 ...

  9. Java编程基础——数组和二维数组

    Java编程基础——数组和二维数组 摘要:本文主要对数组和二维数组进行简要介绍. 数组 定义 数组可以理解成保存一组数的容器,而变量可以理解为保存一个数的容器. 数组是一种引用类型,用于保存一组相同类 ...

  10. 《Java基础——数组的定义与使用》

    Java基础--数组的定义与使用       一. 一维数组: 格式一: 数组类型 数组变量[]=new 数据类型[长度]; //需要后续赋值,且后续赋值时只能为单个元素赋值. 或 数组类型 数组变量 ...

随机推荐

  1. css整理之-----------技巧、黑魔法

    css 看起来比较简单,但是要想做的好也不是那么容易,我们在平时开发中,主要用css 来美化我们的html结构,所有我觉得css 还是挺重要的,这里记录整理一些关于css 的技巧以及容易忘记的知识点. ...

  2. WorkSkill整理之 java用Scanner 类输入数组并打印

    输入不确定长度的数组 import java.util.*; public static void main(String[] args){ System.out.println("请输入一 ...

  3. java mvc 及其缓存

    使用Spring框架的好处是什么? - 轻量:Spring 是轻量的,基本的版本大约2MB. - 控制反转:Spring通过控制反转实现了松散耦合,对象们给出它们的依赖,而不是创建或查找依赖的对象们. ...

  4. ElementUI Tree控件在懒加载模式下的重新加载和模糊查询

    之所以使用懒加载是为了提高性能,而且只有在懒加载模式下默认会给所有显示节点设置展开按钮.leaf也可以做到,但是要操作数据比较麻烦. 要实现懒加载模式下的模糊查询以及重新加载必须要使用data与laz ...

  5. Poj3660(floyd)

    题目传送门 题意:编号为1-N的奶牛参加比赛,告诉我们m场比赛结果试问有几头奶牛的排名可以确定. 题解:其实就是一个传递闭包的模板题,用Floyd把所有有联系的比赛结果串在一起. Ac 代码: #in ...

  6. windbg安装pykd记录

    https://githomelab.ru/pykd/pykd 1.安装python   (坑,分x86和x64,对应windbg版本) 2.安装pykd:'pip install pykd' 3.安 ...

  7. java中if语句的应用

    1. 注释怎么写: 1.1  //单行注释 1.2  /*多行注释*/ 2. If语句的用法 2.1. if(条件语句){ (  ps:只有一行代码时可以不加{}  ) } 2.2. if(条件语句) ...

  8. Java代码实现热部署

    一.思路 0. 监听java文件最后修改时间,如果发生变化,则表示文件已经修改,进行重新编译 1. 编译java文件为 class文件 2. 通过手写类加载器,加载 class文件 ,创建对象 3. ...

  9. Kubernetes,kubectl常用命令详解

    kubectl概述 祭出一张图,转载至 kubernetes-handbook/kubectl命令概述 ,可以对命令族有个整体的概念. 环境准备 允许master节点部署pod,使用命令如下: kub ...

  10. Python面向对象练习题

    1.模拟栈操作原理 先进后出 ​1.初始化(创建一个存储数据的列表) 2.进栈使用列表保存数据 ​ 3.出栈 使用列表删除数据 ​ 4.查看栈顶元素 切片获取列表最后一位数据 ​5.判断是否为空栈 6 ...