方法的递归内存图解

方法的递归

不涉及到new的创建,有栈内存足够。

先将主方法main加载到栈内存中,输出int sum = getSum(5);

getSum方法调用,进入栈内存,getSum(5); return 5 + getSum(4);

继续调用getSum,getSum(4); return 4 + getSum(3);

继续调用getSum,getSum(3); return 3 + getSum(2);

继续调用getSum,getSum(2); return 2 + getSum(1);

继续调用getSum,getSum(1); return 1;

执行完return 1,方法就会消失,同理递推,
return 2 + 1; 执行完消失

return 3 + 3; 执行完消失

return 6 + 4; 执行完消失

return 10 + 5; 执行完消失

sum = 15

输出即可。

方法的递归内存图解