PHP实现递归的三种方法
发布:smiling 来源: PHP粉丝网 添加日期:2022-03-16 15:09:02 浏览: 评论:0
递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则会无限调用下去。
一般来说,递归函数可利用全局变量,引用,静态变量,但需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好的技巧。
一、利用引用做参数
PHP 的引用允许用两个变量来指向同一个内容,例如 $a = &$b; 这意味着 $a 和 $b 指向了同一个变量。
如下例子,因为 $data 使用了引用传递,所以数据会一直累加。
- function recursion(&$data = [], $i = 0)
- {
- if ($i < 10) {
- $data[] = $i;
- $i++;
- $this->recursion($data, $i);
- }
- return $data;
- }
- // 调用
- $this->recursion(); // [0,1,2,3,4,5,6,7,8,9]
二、利用全局变量
global 在函数内申明变量不过是外部变量的同名引用,变量的作用范围仍然在本函数范围内,改变这些变量的值,外部同名变量的值自然也改变了。
- function recursion($data = [], $i = 0)
- {
- global $data;
- if ($i < 10) {
- $data[] = $i;
- $i++;
- $this->recursion($data, $i);
- }
- return $data;
- }
- // 调用
- $this->recursion(); // [0,1,2,3,4,5,6,7,8,9]
三、利用静态变量
静态变量只在第一次调用时初始化,仅在局部函数域中存在,但当程序执行离开此作用域时,其值并不丢失。
- function recursion($i = 0)
- {
- static $data = [];
- if ($i < 10) {
- $data[] = $i;
- $i++;
- $this->recursion($i);
- }
- return $data;
- }
- // 调用
- $this->recursion(); // [0,1,2,3,4,5,6,7,8,9]
Tags: PHP递归方法
- 上一篇:浅析PHP echo 和 print 语句
- 下一篇:最后一页
相关文章
- ·php递归方法实现无限分类实例(2014-06-28)
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)