函数表达式-递归

网友投稿 498 2022-10-26


函数表达式-递归

递归

递归函数是在函数通过调用自身的情况下构成的

1     function factorial(num){2         if (num <=1){3             return 1;4         } else {5             return num * factorial(num-1);6         }7     }

这是一个经典的递归阶乘函数,但是下面的代码会让它出错

1     var anotherFactorial = factorial;2     factorial = null;3     console.log(anotherFactorial(4));//factorial is not a function

在执行anotherFactorial()函数时,factorial已经不是函数了

arguments.callee是一个指向正在执行的函数的指针,因此何以用它来实现对函数的递归调用

1     function factorial(num){2         if (num <=1){3             return 1;4         } else {5             return num * arguments.callee(num-1);6         }7     }

但是在严格模式下,不能通过脚本访问arguments.callee,访问这个属性会导致错误。不过,可以使用命名函数表达式达成相同的结果

1     var factorial = (function f(num){ 2         if (num <= 1){ 3             return 1; 4         } else { 5             return num * f(num -1); 6         } 7     }); 8  9     var anotherFactorial = factorial;10     factorial = null;11     console.log(anotherFactorial(4)); //24


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:面向对象的程序设计-原型模式
下一篇:SpringMVC框架如何与Junit整合看这个就够了
相关文章

 发表评论

暂时没有评论,来抢沙发吧~