如何理解PHP迭代器工作原理,过程是什么
Admin 2022-09-24 群英技术资讯 1134 次浏览
这篇文章我们来了解“如何理解PHP迭代器工作原理,过程是什么”的内容,小编通过实际的案例向大家展示了操作过程,简单易懂,有需要的朋友可以参考了解看看,那么接下来就跟随小编的思路来往下学习吧,希望对大家学习或工作能有帮助。
工作原理
1、在第一次迭代之前,运行iterator::rewind()方法。
只运行一次,返回迭代器的第一个要素,但该方法没有返回值
2、验证第一个元素是否有效。
验证方法可以定制。如果返回值是true,继续执行,如果返回值是false,迭代终止。
3、foreach继续调用Iterator。
返回指定要素的键和值。
4、foreach的方法体
var_dump($key,$value)
5、每次迭代后,调用Iterator决定下一个元素并重复第二步。
实例
string(18) "myIterator::rewind" //迭代开始前调用rewind方法, 返回到迭代器的第一个元素, 同时执行$this->position = 1; string(17) "myIterator::valid" //验证当前元素$this->array[1]是否有效, 有效则继续执行; string(19) "myIterator::current" // 返回当前元素对应的值$this->array[0]='firstelement' string(15) "myIterator::key" // 返回当前元素的键$this->position = 1 int(1) //var_dump($key) string(12) "secondelement" //var_dump($value) string(16) "myIterator::next" //向前移动到下一个元素++$this->position=2 string(17) "myIterator::valid" //验证当前元素$this->array[2]是否有效, 有效则继续执行; string(19) "myIterator::current" //重复之前的步骤 string(15) "myIterator::key" //重复之前的步骤 int(2) //重复之前的步骤 string(11) "lastelement" //重复之前的步骤 string(16) "myIterator::next" //向前移动到下一个元素++$this->position=3 string(17) "myIterator::valid" //验证当前元素$this->array[3]是否有效, 无效则退出遍历
推荐操作系统:windows7系统、PHP5.6、DELL G3电脑
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
php使用array_diff去除元素:1、array_diff() 函数用于比较两个(或更多个)数组的值,并返回差集。2、array_diff() 比较两个数组的值(key=>value 中的 value),并返回一个差集数组。
本文主要给大家分享的是关于laravel数据验证的内容,下文是小编整理的一些laravel数据验证规则,具有一定的参考借鉴价值,有这个方面学习需要的朋友可以参考学习。
Laravel 的验证系统有 60多个验证规则可用,但是如果你需要其他的功能怎么办?你可以 轻松创建自己的验证规则, 也可以使用互联网上已有的验证规则。让我们来看看。
PHP7栏目讲解php7和PHP5对比的新特性和性能优化,有需要的朋友可以看看,了解了解,一起讨论讨论。
这篇文章主要介绍了Laravel框架环境与配置操作,结合实例形式分析了laravel框架基本环境配置方法及维护模式相关操作技巧,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008