正文

“条件递进式编程”技巧两例2008-06-03 17:02:00

【评论】 【打印】 【字体: 】 本文链接:http://blog.pfan.cn/aurora/35863.html

分享到:

转自:http://blog.csdn.net/happydeer/archive/2004/08/06/66743.aspx#785737 什么是“条件递进式编程”?呵呵,这是我自己起的名字。所谓条件递进式编程,就是指需要一系列相关函数组合执行的情况下,后续函数执行的必要性由前面所有函数执行是否成功来决定。比如说,有一系列函数如下DoSomething1、DoSomething2、DoSomething3......DoSomethingN;DoSomething2函数执行的前提是DoSomething1函数必须执行成功,DoSomething3函数执行的前提是DoSomething1和DoSomething2都执行成功,DoSomethingN函数执行的前提是DoSomething1、DoSomething2、DoSomething3......DoSomething(N-1)都执行成功。 你会如何来写这段程序?不假思索,你可能会如下编写: BOOL DoSomething(){ if (DoSomething1()) {  if (DoSomething2())  {   if (DoSomething3())   {    // ...    return TRUE;   }  } } return FALSE;} 这种层层嵌套的结构,逻辑上并没有错,但代码的可读性就差了一点。如果系列函数的数量很多(即上述N的值很大),那么整个代码结构的宽度将变得很长,代码的可读性将进一步降低,日后修改代码的时候也很容易出错。 下面,我将给出两种我本人认为很不错的程序结构。这两种程序结构不是我自创的,但我能看到它们智慧的光芒。另外,关于以下两种程序结构,我不想给出过多解释,读者用心慢慢体会吧! 程序结构1: BOOL DoSomething(){ BOOL pass = DoSomething1(); if (pass) {  pass = DoSomething2(); } if (pass) {  pass = DoSomething3(); } if (pass) {  // ... } return pass;} 程序结构2: BOOL DoSomething(){ BOOL pass = FALSE;  do {  if (!DoSomething1())  {   break;  }  if (!DoSomething2())  {   break;  }  if (!DoSomething3())  {   break;  }  // ...   pass = TRUE; } while (FALSE); return pass;}

阅读(3309) | 评论(0)


版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!

评论

暂无评论
您需要登录后才能评论,请 登录 或者 注册