C#关于递归
输出是多少?
考虑这样一段代码传入参数1,输出会是什么?
1233?
然而实际上是123321。
这说明,当1进入递归时,前一个函数并没有结束,而是挂起先执行Test(2),2进入递归,挂起执行Test(3),跳过递归语句,输出Console2:3,然后执行最后挂起的Test(2)后面的语句,Console2:2,执行挂起的Test(1),Console2:1.
分析过程
再看这一段语句
来分析一下执行过程:
参数1进入,输出Console1:1,
判断小于3,然后递归,挂起Test(1),执行Test(2),输出Console1:2
,递归,挂起Test(2),执行Test(3),输出Console1:3
跳过递归语句,输出Console2:3
输出“HelloWorld!”
return num(3),执行最后挂起的Test(2),return 1000,执行Test(1),return 1000,返回的是最后的1000,输出FinallNum:1000
递归的结论:挂起
这一点可以证明递归不是结束,而是挂起,考虑这样输出最后是多少?
相信你一定有了答案,动手验证一下,看看对不对
逐语句测试
使用逐语句,看一下代码的执行顺序,看看变量的变化
逐语句执行:执行完 最后的 return num会回到Test(num+1)执行两遍