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)执行两遍

posted @ 2020-11-22 13:43  euph  阅读(75)  评论(0编辑  收藏  举报