什么是“条件递进式编程”?呵呵,这是我自己起的名字。所谓条件递进式编程,就是指需要一系列相关函数组合执行的情况下,后续函数执行的必要性由前面所有函数执行是否成功来决定。比如说,有一系列函数如下dosomething1、dosomething2、dosomething3......d
什么是“条件递进式编程”?呵呵,这是我自己起的名字。所谓条件递进式编程,就是指需要一系列相关函数组合执行的情况下,后续函数执行的必要性由前面所有函数执行是否成功来决定。比如说,有一系列函数如下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;
}