js实现阶乘函数的问题

书上说下面这样写不好。

function factorial(num) {
    if(num <= 1) {
        return 1;
    } else {
        return num * factorial(num - 1); 
    }
}

要写成这样才好:

function factorial(num) {
    if(num <= 1) {
        return 1;
    } else {
        return num * arguments.callee(num - 1); 
    }
}

为什么?

阅读 11.8k
3 个回答

第一种实现方式依赖于外层函数的名称factorial,而factorial可能会在后来被其他值改写
第二种实现方式不依赖于函数的名称,而是用arguments对象的callee属性来指向外层函数

第二种的好处,Joe3已经说了。
但坏处是:arguments.callee的性能不佳,已经被标准所摈弃了。
所以其实第一种反而是目前标准推荐的写法。

考虑到你不太可能经常变换函数名称,而且即使变换了,顺手把递归部分一起改掉,也不会是什么麻烦事,所以还是按标准写吧。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题