php实现递归的三种方式: 遍历文件夹实例
2016-11-21 10:28
686 查看
递归函数是我们常用到的一类函数,最基本的特点是函数自身调用自身,但必须在调用自身前有条件判断,否则无限无限调用下去。实现递归函数可以采取什么方式呢?本文列出了三种基本方式。理解其原来需要一定的基础知识水品,包括对全局变量,引用,静态变量的理解,也需对他们的作用范围有所理解。递归函数也是解决无限级分类的一个很好地技巧。
1.利用引用做参数
先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在可好,两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一室了。因而任何对存储地址数值的改变都会影响两个值。
函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。
利用全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。
3静态变量
我们常常在类中见到static,今天我们把它利用到递归函数中。请记住static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。
1.利用引用做参数
先不管引用做不做参数,必须先明白引用到底是什么?引用不过是指两个不同名的变量指向同一块存储地址。本来每个变量有各自的存储地址,赋值删除各行其道。现在可好,两个变量共享一块存储地址。 $a=&$b; 。实际上指的是 $a 不管不顾自己原来的存储地址,非要和 $b 共享一室了。因而任何对存储地址数值的改变都会影响两个值。
函数之间本来也是各行其是,即便是同名函数。递归函数是考虑将引用作为参数,成为一个桥梁,形成两个函数间的数据共享。虽然两个函数见貌似操作的是不同地址,但是实际上操作的是一块儿内存地址。
/******闭包测试********/ $dir = 'E:/test/projects/'; function getdir( $dir,&$arr = array()){ //static $arr= array(); if(is_dir($dir)){ $hadle = @opendir($dir); while($file=readdir($hadle) ) { if(!in_array($file,array('.','..')) ) { $dir = $dir.$file."/"; array_push($arr,$dir); if(is_dir($dir)) { getdir( $dir ,$arr); } } } } } $arr= array(); getdir($dir,$arr); var_dump($arr); //results:array(3) { [0]=> string(19) "E:/test/projects/1/" [1]=> string(24) "E:/test/projects/1/2222/" [2]=> string(21) "E:/test/projects/1/2/" } 2.全局变量
利用全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引用。变量的作用范围仍然在本函数范围内。改变这些变量的值,外部同名变量的值自然也改变了。但一旦用了&,同名变量不再是同名引用。利用全局变量实现递归函数没必要理解到这么深的一层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。
function getdirglo( $dir ,$arr =array()){ global $arr; if(is_dir($dir)){ $hadle = @opendir($dir); while($file=readdir($hadle) ) { if(!in_array($file,array('.','..')) ) { $dirr = $dir.$file."/"; array_push($arr,$dirr); if(is_dir($dirr)) { getdirglo( $dirr ,$arr); } } } } } $arr = array(); getdirglo($dir,$arr); var_dump($arr);
3静态变量
我们常常在类中见到static,今天我们把它利用到递归函数中。请记住static的作用:仅在第一次调用函数的时候对变量进行初始化,并且保留变量值。
function getdirglo( $dir ){ static $arr = array(); if(is_dir($dir)){ $hadle = @opendir($dir); while($file=readdir($hadle) ) { if(!in_array($file,array('.','..')) ) { $dirr = $dir.$file."/"; array_push($arr,$dirr); if(is_dir($dirr)) { getdirglo( $dirr); } } } } return $arr; } $arr = array(); $arr = getdirglo($dir); var_dump($arr);
相关文章推荐
- 用非递归方式实现二叉树的前、中、后三种遍历方法
- 二叉树的三种遍历方式的递归实现和非递归实现
- php实现递归的三种基本方式
- php实现递归的三种基本方式
- 详细讲解二叉树三种遍历方式的递归与非递归实现
- 二叉树的三种遍历方式(递归和非递归的实现方法)
- php实现递归的三种基本方式
- Java三种遍历方式打印二叉树(递归实现)
- php实现递归的三种基本方式
- PHP递归遍历指定文件夹内的文件实现方法
- 二叉树三种遍历方式的递归与非递归实现
- 详细讲解二叉树三种遍历方式的递归与非递归实现
- PHP实现递归复制整个文件夹的类实例
- 详细讲解二叉树三种遍历方式的递归与非递归实现
- 二叉树三种遍历方式 递归与非递归实现 总结
- 递归方式遍历文件夹下的所有文件及子文件夹 [php]
- PHP实现递归复制整个文件夹的类实例
- 二叉树三种遍历方式非递归实现
- 二叉树的三种遍历方式的递归实现和迭代实现
- 二叉树的前序、中序、后序三种遍历的六种实现方式(递归、非递归)(C++)