【web 开发基础】PHP 循环结构之 for 循环 -PHP 快速入门 (19)

简介: 虽然前面介绍的while和do...while循环是使用计数方式控制循环的执行,但这两种循环通常用于条件型循环,即是遇到特定的条件才停止循环.而for循环语句适用于明确知道重复执行次数的情况,它的格式和前面两种循环语句不一样,for语句将循环次数的变量预先定义好.虽然for语句是PHP中最复杂的循环结构,但for循环时最常用的,而且用于计数方式控制循环,其使用更为方便。

for循环结构

虽然前面介绍的while和do...while循环是使用计数方式控制循环的执行,但这两种循环通常用于条件型循环,即是遇到特定的条件才停止循环.而for循环语句适用于明确知道重复执行次数的情况,它的格式和前面两种循环语句不一样,for语句将循环次数的变量预先定义好.虽然for语句是PHP中最复杂的循环结构,但for循环时最常用的,而且用于计数方式控制循环,其使用更为方便。for循环语法格式如下:

for(初始化; 条件表达式; 增量){
   语句块; //循环体
}

for语句是由分号分隔的三部分组成的,其中的初始化、条件表达式和增量都是表达式。初始化总是一个赋值语句,它用来给循环控制变量赋初值。条件表达式是一个关系表达式,它决定什么时候推出循环;增量定义循环控制变量,每循环一次后按什么方式变化。而语句块可以是单条语句和复合语句,如果是单条语句也可以不使用花括号“{}”。但还是那句话:避免出错,不管单条语句还是复合代码块,建议养成好习惯,都写上花括号“{}”括住语句块;程序执行到for语句时,将会发生以下情况:

  1. 第一次进入for循环时,对循环控制变量赋初值。
  2. 根据判断条件的内容检查是否要继续执行循环。如果判断条件为真,则继续执行循环,如果判断条件假,则结束循环执行下面的语句
  3. 执行完循环体内的语句后,系统会根据循环控制变量增减方式,更改循环控制变量的值,再回到步骤2重新判断是否继续执行循环。

我们在介绍while循环的时候写过一个循环输出的例子,我们现在使用for循环来写,对比一下

<?php$i=1;
while($i<=10){
echo"这是第" . $i . "次输出结果<br>";
$i++;
}

下面看看for是怎么实现的

for($i=1;$i<=10;$i++){
  echo "这是第" . $i . "次输出结果<br>";
}

执行结果:

for循环的写法看起来好像更加简洁。先给变量$i赋初值1,接着判断变量$i是否小于等于10,如果条件成立则执行输出语句.之后变量$i自增1,再重新判断,直到条件为假,结束循环.

在for循环中的三个表达式中,一个或多个表达式为空是允许的,通常被称为for循环的退化形式.可以将前面的例子写成以下几种形式:

<?phpfor($i=1;$i<=10;$i++){
echo"这是第" . $i . "次输出结果<br>";
}
echo"<hr>"; //<hr>是html中一个分隔标签:一条分隔线//把赋初值语句提到外面写,但是for语句中的分号要保留$i=1;
for(;$i<=10;$i++){
echo"这是第" . $i . "次输出结果<br>";
}
echo"<hr>";
//将第三部分的增量提出来,放到循环体里面,同样需要保留分号(;)$i=1;
for(;$i<=10;){
echo"这是第" . $i . "次输出结果<br>";
$i++;
}
echo"<hr>";
//把第二部分的条件表达式放到循环体里面,但是在for语句中,两个分号是必须存在的,就算啥也没写,当你啥也没写的时候就是死循环,相当于while(true){...}$i=1;
for(;;){
if($i>10){
break;
  }
echo"这是第" . $i . "次输出结果<br>";
$i++;
}

执行结果:

上面的例子中,如果for语句中留空,而且循环体没有语句执行跳出循环,for语句会一直运行,形成死循环,直到把内存耗尽,程序崩溃,严重还会导致宕机等一系列事故,所以非必要,一定要避免在程序中出现死循环

上面的例子中,第一种写法比较正常,也是最常用的写法,但可能会发现在for循环中用空的表达式在很多场合都很方便,不仅可以将for语句中的一个或多个表达式设为空,还可以在每个表达式中编写多条件语句:

<?phpfor($i=1,$j=5,$k=10;$i<=10;$i++,$j+=5,$k+=10){
echo"\$i的值是:".$i."\$j的值是:".$j."\$k的值是:".$k."<br>";
}

执行结果如下:

在第一个表达式中初始化三个变量,变量之间用逗号隔开,在第二个表达式中,不管怎样写,最后一定要是一个布尔类型的值,第三个表达式中,分别见三个变量设置成不同增量值

不管是多写几个初始条件还是多写几个增量,只要是合法的表达式,都可以写在for语句的三个表达式中,中间使用逗号分隔开即可.

编程实践

for循环也可以像while循环一样嵌套使用,即在for语句中包含另一条for语句.通过对for语句进行嵌套,可以完成一些复杂的编程.下面我们通过输出九九乘法表来了解双层嵌套for语句的写法:

<?phpfor($i=1;$i<=9;$i++){
for($j=1;$j<=$i;$j++){
echo"$jx $i= " . ($j*$i) . "&nbsp;&nbsp;";
  }
echo"<br>";
}

执行结果:

另外在编写计数控制循环语句是,计数的变量不仅可以递增,还可以递减.我们将上的例子的递增条件改为递减,看会有什么奇迹发生:输出的结果就会是从大到小?

<?phpfor($i=9;$i>=1;$i--){
for($j=$i;$j>=1;$j--){
echo"$jx $i= " . ($j*$i) . "&nbsp;&nbsp;";
  }
echo"<br>";
}

执行结果:

从执行的结果我们可以看到结果是从大到小,刚好是递增的结果倒过来.从一个正三角变成一个倒三角,for循环是我们日常开发中最常用的一种循环结构,多写多练,一定要学好他,成为大神指日可待~哈哈O(∩_∩)O哈哈~

目录
相关文章
|
10天前
|
关系型数据库 MySQL
web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}
web简易开发(二){html5+php实现文件上传及通过关键字搜索已上传图片)}
|
6天前
|
安全 测试技术 PHP
掌握现代Web开发:PHP 8的新特性与最佳实践
【5月更文挑战第5天】 在当今快速发展的网络世界中,PHP作为一种流行的服务器端脚本语言,持续地演化着。最新的PHP 8版本引入了一系列令人兴奋的新特性和性能改进,为开发者提供了更加强大和灵活的工具。本文将深入探讨PHP 8中的新特性,包括联合类型、名称参数、匹配表达式等,并分享一些最佳实践,帮助开发者提高代码质量,优化性能,并确保安全性。通过这些实用技巧和示例,您将能够构建更高效、更安全的PHP应用程序。
|
12天前
|
前端开发 JavaScript 测试技术
【PHP开发专栏】PHP Web开发基础与流程
【4月更文挑战第29天】本文介绍了PHP Web开发的基础和流程,帮助初学者入门。内容包括Web服务器与PHP解释器的工作原理、HTML/CSS/JavaScript基础知识、PHP语法与数据库操作。开发流程涵盖项目规划、环境搭建、数据库设计、代码编写、测试与调试,以及部署与维护。此外,文中还强调了使用框架、代码组织、安全性及性能优化等进阶知识和最佳实践,旨在培养优秀PHP开发者。
|
15天前
|
PHP 开发者
提升Web开发效率:深入PHP的高级特性与最佳实践
【4月更文挑战第27天】 在现代Web开发的浪潮中,PHP作为一种流行的服务器端脚本语言,其灵活性和易用性为开发者所推崇。本文将深入探讨PHP的高级特性,并结合最佳实践原则来提高开发效率和代码质量。我们将从PHP的命名空间、匿名函数、闭包等概念出发,探索如何通过这些特性来构建更加模块化和可维护的代码结构。此外,文章还将介绍如何利用PHP内置的错误处理机制、自动加载功能以及新兴的Composer依赖管理工具,来优化开发流程。通过实例分析与经验分享,我们希望能够帮助PHP开发者在项目实践中达到更高的技术水平。
|
23天前
|
安全 编译器 PHP
PHP 8.1版本发布:引领Web开发新潮流
PHP编程语言一直是Web开发的主力军,而最新发布的PHP 8.1版本则为开发者们带来了更多创新和便利。本文将介绍PHP 8.1版本的主要特性,包括更快的性能、新的语言功能和增强的安全性,以及如何利用这些功能来提升Web应用程序的质量和效率。
|
1天前
|
编解码 数据库 计算机视觉
LabVIEW开发基于Web数字图像处理
LabVIEW开发基于Web数字图像处理
|
3天前
|
前端开发 JavaScript Java
Java与Web开发的结合:JSP与Servlet
Java与Web开发的结合:JSP与Servlet
8 0
|
3天前
|
存储 程序员 API
python web开发示例详解
python web开发示例详解
13 0
|
4天前
|
XML 前端开发 JavaScript
CSR(客户端渲染)和AJAX在Web开发中各自扮演不同的角色
【5月更文挑战第8天】CSR(客户端渲染)与AJAX在Web开发中各司其职。CSR提供初始HTML框架,通过JavaScript在浏览器端获取并渲染数据,提升交互性和响应速度。AJAX则实现页面局部更新,如实时搜索,不刷新页面即可获取数据。CSR可能因DOM操作多而引发性能问题,但可优化解决;AJAX适合频繁交互场景,提高响应性。两者在不同需求下各有优势,需按项目选择适用技术。
13 4
|
4天前
|
前端开发 搜索推荐 安全
AJAX和CSR(客户端渲染)是Web开发中常用的两种技术
【5月更文挑战第8天】AJAX提升用户体验,减轻服务器压力,但对搜索引擎不友好且增加开发复杂度,易引发安全问题。CSR提供快速响应和交互性,改善用户体验,但首屏加载慢,搜索引擎支持不足,同样面临安全挑战。两者各有适用场景,需按项目需求选择。
10 0