javascript 递归函数调用(recursive funciton call)

Posted 牛顿的小脑

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript 递归函数调用(recursive funciton call)相关的知识,希望对你有一定的参考价值。

所谓的递归函数调用,就是自己调用自己的函数。

1 var timerHandler = null;
2 function a(){
3     console.log(123);
4     timerHandler = setTimeout(a, 1000)    ;
5 }
6 a();
7 //clearTimeout(timerHandler);

 

-----------------------------------------------------------------------------------------

/* Count down to 0 recursively.
 */
var functionHolder = function (counter) {
    console.log(counter);
    if (counter > 0) {
        functionHolder(counter-1);
    }
}

 

With this, functionHolder(3); would output 3 2 1 0. Let‘s say I did the following:

var copyFunction = functionHolder;
copyFunction(3); would output 3 2 1 0 as above. If I then changed functionHolder as follows:
functionHolder = function(whatever) {
    console.log("Stop counting!");
}

  

Then functionHolder(3); would give Stop counting!, as expected.

copyFunction(3); now gives 3 Stop counting! as it refers to functionHolder, not the function (which it itself points to). This could be desirable in some circumstances, but is there a way to write the function so that it calls itself rather than the variable that holds it?

That is, is it possible to change only the line functionHolder(counter-1); so that going through all these steps still gives 3 2 1 0 when we call copyFunction(3);? I tried this(counter-1); but that gives me the error this is not a function.

----------------------------------------------------------------------------------------------

Using Named Function Expressions:

You can give a function expression a name that is actually private and is only visible from inside of the function ifself:

var factorial = function myself (n) {
    if (n <= 1) {
        return 1;
    }
    return n * myself(n-1);
}
typeof myself === ‘undefined‘

Here myself is visible only inside of the function itself.

You can use this private name to call the function recursively.

See 13. Function Definition of the ECMAScript 5 spec:

The Identifier in a FunctionExpression can be referenced from inside the FunctionExpression‘s FunctionBody to allow the function to call itself recursively. However, unlike in a FunctionDeclaration, the Identifier in a FunctionExpression cannot be referenced from and does not affect the scope enclosing the FunctionExpression.

Please note that Internet Explorer up to version 8 doesn‘t behave correctly as the name is actually visible in the enclosing variable environment, and it references a duplicate of the actual function (see patrick dw‘s comment below).

 

以上是关于javascript 递归函数调用(recursive funciton call)的主要内容,如果未能解决你的问题,请参考以下文章

结合记忆和尾递归

如何在 Scala 中使用 Stream.cons 编写不泄漏的尾递归函数?

javascript 递归函数调用(recursive funciton call)

JavaScript-函数(调用参数returnarguments匿名回调递归函数)函数案例

JavaScript 递归

Javascript学习笔记:3种递归函数中调用自身的写法