在上一课中处理错误,我们讨论了使用方法assert(),cerr(),和exit()处理错误。然而,我们谈及的话题,现在我们将进一步包括:例外。
当返回代码失败
编写可重用的代码时,错误处理是必要的。一种处理潜在的错误的最常见的方式是通过返回代码。例如:
1
2
3
4
5
6
7
8
9
10
11
int FindFirstChar(const char* strString, char chChar)
{
// Step through each character in strString
for (int nIndex=0; nIndex < strlen(strString); nIndex++)
// If the charater matches chChar, return it's index
if (strString[nIndex] == chChar)
return nIndex;
// If no match was found, return -1
return -1;
}
这个函数返回第一个字符匹配chchar在strstring指数。如果字符无法找到,该函数返回1错误指示器。
这种方法的主要优点是,它是非常简单的。然而,使用返回代码有许多缺点,它可以很快变得明显时,用非平凡的情况:
首先,返回值可以是神秘的,如果一个函数返回1,是它试图显示错误,或是实际有效的返回值?告诉没有挖掘到的功能的胆量,常常很难。
第二,函数只能返回一个值,所以当你需要返回一个函数的结果和错误代码?考虑下面的函数:
1
2
3
4
双Divide(int int NX,纽约)
{
返回静态_ CAST <双>(NX)/纽约;
}