当我没有定义参数时,为什么会出现无限循环?

时间:2012-07-24 15:46:46

标签: javascript algorithm

我想知道为什么我在这里得到一个无限循环。我只是不想传递这个初始值,所以如果它们是undefined,它们会自动计算出来。它只是为了清理我的函数调用只使用一个参数。如果我通过它们,一切运行正常,过程结束。有人可以帮忙吗?感谢

function merge(array, lower, half, upper){
    //Suppressed for the sake of brevity
}

function mergeSort(array, lower, upper){
    if(!lower && !upper){ //take a look here
        lower = 0;
        upper = array.length - 1;
    }

    if(lower < upper){
        var half = Math.floor((lower + upper)/2);

        mergeSort(array, lower, half);
        mergeSort(array, half + 1, upper);
        merge(array, lower, half, upper);
    }
}

var array = [8, 3, 6, 4, 1, 0, 23, 12, 15, 63];
mergeSort(array); //infinite loop here
console.log(array);

1 个答案:

答案 0 :(得分:7)

你对mergeSort的第一次递归调用将0作为第一个参数传递,因为你设置了它。

由于!0也会对false进行评估,所以你可以去..

使用undefined运算符

更好地检查typeof
if(typeof lower === 'undefined' && typeof upper === 'undefined'){ //take a look here
    lower = 0;
    upper = array.length - 1;
}

或者更好的是,检查arguments.length,例如

if( arguments.length === 1 ) {
   var lower = 0,
       upper = array.length -1 ;
}