从递归函数修改全局变量不能按预期工作

问题描述 投票:-2回答:2

我尝试使用全局变量生成一个递归函数来计算从1到n的和,但它似乎没有按预期工作。

有人能为我解释原因吗?以下是javascript中的代码。

s = 0;

function sum(n) {
  if (n === 1) {
    return 1;
  }
  else {
    s = s + n + sum(n - 1);
  }
  return 0;
}

sum(5);

console.log('The sum from 1 to 5 is ' + s); // this return wrong value

我的目的是为全局变量s创建一个副作用。因此,我假设所有堆栈帧都将按此顺序调用,每次弹出时(从下往上),s值将相应更新。如果我理解错了,请更正。

s = s + 5 + sum(4)  // s = 10 + 5 + 0
return 0
------------------
s = s + 4 + sum(3)  // s = 6 + 4 + 0
return 0
------------------
s = s + 3 + sum(2)  // s = 3 + 3 + 0
return 0
------------------
s = s + 2 + sum(1)  // s = 0 + 2 + 1 
return 0
------------------
return 1            // s = 0 (from global)
javascript variables recursion sum global
2个回答
© www.soinside.com 2019 - 2024. All rights reserved.