不常见的控制结构
1.子程序中的多处返回
- 如果能增强可读性,那么就使用return
- 用防卫子句(早返回或早退出)来简化复杂的错误处理
- 减少每个子程序中return的数量
2.递归
在递归里面,一个子程序自己负责解决某个问题的一小部分,它还把问题分解成很多的小块,然后调用自己来分别解决每一小块。
对于某一小范围内的问题,使用递归会带来简单、优雅的解。在稍大一些范围里,使用递归会带来简单、优雅但是难懂的解。对于大多数问题,它所带来的解将会是极其复杂的——在那些情况下,使用简单的迭代通常会比较容易理解。因此要有选择地使用递归。
1)使用递归的技巧
- 确认递归能够停止
- 使用安全计数器防止出现无穷递归
- 把递归限制在一个子程序内
- 留心栈空间
- 不要用递归去计算阶乘或者斐波纳契数列
3.goto
对于goto,人们总是持两种观点:反对和支持。用不用goto是一个信仰问题。我的信条是,在现代语言里,你可以很容易地把九成的goto替换成与之等价的顺序结构。对于这些简单的情况,你应该把goto替换掉并把这当成习惯。对于复杂的情况,你仍有九成不用goto的可能:你可以把代码拆分成小的子程序,使用try-finally,使用嵌套if,检测并重新检测某个状态变量,或者重新设置条件结构。对于这些情况,想消除goto相对来说比较困难,但这是一种很好的智力训练。
4.针对不常见控制结构的观点