- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PHP递归函数原理及调⽤⽅法
递归函数是⼀个让⼈头疼的运⾏机制,最基本的特点是函数本⾝进⾏⾃调⽤,但是需要在调⽤⾃⾝前进⾏判断,满⾜了调⽤条件就进⾏函数
的调⽤,否则退出调⽤,推出后将本程序流程的控制权交还给上⼀层函数执⾏,否则将进⼊⽆限调⽤机制⽆法退出,从⽽造成死循环,递归
函数的调⽤⽅式⼤概有三种。
1.利⽤引⽤做参数
先不管引⽤做不做参数,必须先明⽩引⽤到底是什么?引⽤不过是指两个不同名的变量指向同⼀块存储地址。本来每个变量有各⾃的存储地
址,赋值删除各⾏其道。现在可好,两个变量共享⼀块存储地址。 $a=$b; 。实际上指的是 $a 不管不顾⾃⼰原来的存储地址,⾮要和 $b
共享⼀室了。因⽽任何对存储地址数值的改变都会影响两个值。
函数之间本来也是各⾏其是,即便是同名函数。递归函数是考虑将引⽤作为参数,成为⼀个桥梁,形成两个函数间的数据共享。虽然两个函
数貌似操作的是不同地址,但是实际上操作的是⼀块⼉内存地址。
function test($a=0,$result=array()){
$a++;
if ($a10) {
$result[]=$a;
test($a,$result);
}
echo $a;
return $result;
}
上⾯的例⼦⾮常简答,以a10作为判断条件,条件成⽴,则把a赋给result[];将result的引⽤传⼊函数,会将每⼀次递归产⽣的a添加到结果
数组result。因⽽本例⽣成的$result数组是 Array ( [0] = 1 [1] = 2 [2] = 3 [3] = 4 [4] = 5 [5] = 6 [6] = 7 [7] = 8 [8] = 9
) 。
本例⽐较有意思的是echo a的值。相信很多⼈认为是12345678910吧,其实不然,是1098765432。为什么呢?因为函数还没执⾏
echoa前就进⾏了下⼀次的函数递归。真正执⾏echo a是当a10条件不满⾜的时候,echo a,返回result,对于上⼀层⽽⾔,执⾏完递归函
数,开始执⾏本层的echo $a,依次类推。
2.利⽤全局变量
利⽤全局变量完成递归函数,请确保你确实理解什么是全局变量。global在函数内申明变量不过是外部变量的同名引⽤。变量的作⽤范围仍
然在本函数范围内。改变这些变量的值,外部同名变量的值⾃然也改变了。但⼀旦⽤了,同名变量不再是同名引⽤。利⽤全局变量实现递
归函数没必要理解到这么深的⼀层,还保持原有对全局变量的看法就可以顺理成章理解递归函数。
function test($a=0,$result=array()){
global $result;
$a++;
if ($a10) {
$result[]=$a;
test($a,$result);
}
return $result;
}
3.利⽤静态变量
我们常常在类中见到static,今天我们把它利⽤到递归函数中。请记住static的作⽤:仅在第⼀次调⽤函数的时候对变量进⾏初始化,并且保
留变量值。
举个例⼦:
function test(){
static $count=0;
echo $count;
$count++;
}
test();
test();
test();
test();
test();
这⼀段代码的执⾏结果是多少?是00000么?必然不是。是01234。⾸先第⼀次调⽤test(),static对 $count 进⾏初始化,其后每⼀次执
⾏完都会保留 $count 的值,不再进⾏初始化,相当于直接忽略了 static $count=0; 这⼀句。
因⽽将static应⽤到递归函数作⽤可想⽽知。在将需要作为递归函数间作为“桥梁的变量利⽤static进⾏初始化,每⼀次递归都会保留桥梁
变量的值。
function test($a=0){
static $result=array();
$a++;
if ($a10) {
$result[]=$a;
test($a);
}
return $result;
}
⼩结:
所谓递归函数,重点是如何处理函数调⽤⾃⾝是如何保证所需要的结果得以在函数间合理传递,当然也有不需要函数之间传值得递归函
文档评论(0)