匿名函数和闭包规避xdebug限制的函数递归深度限制-创新互联
PHP版本5.6
10年积累的网站制作、网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有新昌免费网站建设让你可以放心的选择与我们合作。先来个简单的用递归求和,代码如下:
function add($n){ if($n === 1)return 1; return add($n - 1); } echo add(256); 运行时报错: Maximum function nesting level of '256' reached, aborting!
这个报错的意思就是函数的递归深度大是256,不能大于或等于256.在网上查找资料发现,这个是xdebug做的限制,可以通过更改配置文件来修改这个深度,xdebug.max_nesting_level = ***;但是随着$n值的变大,同样会出现这个问题。
尝试用尾递归来试试,代码如下:
function add($n,$acc = 1) { if($n === 1)return $acc; return add($n - 1,$acc + $n); }
用这样的方式并不能解决问题,最后在网上找资料,发现了用匿名函数和闭包可以规避这种栈溢出的问题。代码如下:
function add($n,$acc = 1) { if($n === 1)return $acc; return function() use ($n,$acc){ return add($n - 1,$acc + $n); }; } function tem($callback,$params) { // $result = call_user_func_array($callback, $params); // while(is_callable($result)){ // $result = $result(); // } // return $result; $a = add($callback,$params); while (!is_int($a)) { $a = $a(); } return $a; } var_dump(tem(10,1)); // echo tem('add',array(10));
刚开始看别人的博客,说这个是因为高级函数call_user_func_array()在中间起的作用,后来把代码修改了一下,发现其实和这个高级函数并没有多大关系,只是和匿名函数和闭包有关,但具体内部做了什么优化,暂时不得而知。
尾记:正如鸟哥所说的,其实我们碰到的大部分递归,都是尾递归,能用一个循环来解决。这样可以节省很多时间和资源。所以,能不用递归尽量不要用递归吧。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
名称栏目:匿名函数和闭包规避xdebug限制的函数递归深度限制-创新互联
文章地址:http://scyanting.com/article/ecsoe.html