解读递归和迭代的区别(实例说明)

话不多说,我们先用偏官方的语言来讲解一下什么是递归和迭代

方法调用自身称为递归;利用变量的原值退出新值称之为迭代。

那么各自都有什么优缺点呢?

 

递归

  • 优点:大问题转换为小问题,可以减少代码量,同时在代码精简的基础上,造成可读性好。
  • 缺点:递归调用浪费了空间,而且递归太深的时候容易造成堆栈溢出。

 

迭代

  • 优点:代码运行效率好,因为时间只是与循环次数呈一个线性关系,而且没有额外的空间开销;也就是空间复杂度降低。
  • 缺点:代码相交递归来说,不够简洁,可读性较差。

 

时间项目经验总结两者的取舍问题:

那么实际的开发过程中,我们如何取舍呢?对于笔者的项目经验中,几乎是使用递归来完成业务需求的,很多的层级树、功能点树都是使用递归的,原因在于什么呢?就是因为他思路更清晰,虽然说可能需要写两个方法之类的,但是在传统的web项目中,少不了有新人、或者团队协作中其他开发者接触到每个人的代码,那么对于自己的代码,不仅要算法效率高,还要考虑一个可读性,对于可读性,我个人觉得是必须存在的,项目的一个交接,一个赏心悦目,都得考虑,所以我们在平时写一个算法的时候,必须考虑到代码的可读性,不能太多的玩“骚操作”,不然这无疑是对接触你代码的人的一个巨大考验。而且不仅对于其他人,可能自己而言,这套逻辑,半个月没接触了,然后注释可能写的不是很直观,那么你需要对这段code进行一个修改,更新。自己捡起来也是很困难的。所以关于上面两者的取舍,我认为优先考虑可读性。

那么我们考虑到了可读性,那么也得对其的弊端进行一个解决方案。递归是一个很容易造成溢出的算法,所以在笔者的实际开发中都会对递归的层次设定一个最大值,那么这个最大值是容许范围内的,那么说,对于一个业务需求来说,可能这段代码,这个递归所解决的需求,我作为实现开发人员,我很清楚的知道它是有一个最大值的,且在这个递归最大深度值里面,是可以保证完成递归需要的,所以说,如果递归达到这个最大值的时候,那么递归就必须返回,即使没有完成(如果没有完成,那就是异常情况了)。

 

 

 

posted @ 2019-10-19 11:17  CHANGEMAX  阅读(1213)  评论(0编辑  收藏  举报