一、数组的概述
* 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. hibernate中关系映射的配置问题

    部门和员工属于一对多的关系 员工的账户属于一对一关系 账户和权限属于多对多关系 department.hbm.xml 1 <hibernate-mapping> 2 <class n ...

  2. Pytorch编程记录

    搭建网络的方式: 1.用sequential方式搭建,只能适用于线性网络 2.用forward和init方式搭建

  3. 实验: survivor放不下的对象进入老年代

    实验一: 存活对象包含 小于survivor大小的对象 + 大于survivor的对象 private static final Integer _1MB = 1024 * 1024; /** * - ...

  4. 【体系结构】Oracle进程架构

    Client Process的介绍 Client and Server Processes Client Process代表着客户端进程,每一个客户端进程关联着一个Server Process(服务器 ...

  5. P1164_小A点菜(JAVA语言)

    思路 简单动态规划问题 题目背景 uim神犇拿到了uoi的ra(镭牌)后,立刻拉着基友小A到了一家--餐馆,很低端的那种. uim指着墙上的价目表(太低级了没有菜单),说:"随便点" ...

  6. 使用Jenkins + git submodule 实现自动化编译,解决代码安全性问题

    道哥的第 030 篇原创 目录 一.一个真实的代码泄漏故事 二.Jenkins 的基本使用 1. Jenkins 是什么? 2. 安装 JDK8 3. 安装 Jenkins 4. 在浏览器中配置 Je ...

  7. ubuntu系统编译安装OpenCV 4.4

    内容转载自我的博客 目录 前言 1. 下载源码 2. 安装各种依赖 3. 开始编译安装 4. 配置C++开发环境 5. 程序执行时加载动态库*.so 6. 测试cpp文件 7. 配置python3的o ...

  8. [单调栈]Imbalanced Array

    I m b a l a n c e d A r r a y Imbalanced Array ImbalancedArray 题目描述 You are given an array a a a con ...

  9. python基础(一):变量和常量

    变量 什么是变量 变量,用于在内存中存放程序数据的容器.计算机的核心功能就是"计算",CPU是负责计算的,而计算需要数据吧?数据就存放在内存里,例如:将梁同学的姓名,年龄存下来,让 ...

  10. DDD实战让中台和微服务的落地如虎添翼

    微服务到底怎么拆分和设计才算合理,拆多小才叫微服务?有没有好的方法来指导微服务和中台的设计呢? 深入DDD的核心知识体系与设计思想,带你掌握一套完整而系统的基于DDD的微服务拆分与设计方法,助力落地边 ...