对于使用异常,普遍存在以下几种观点:
1. 尽量少用异常。
2. 将很少发生的错误认定为异常
3. 可以用异常屏蔽一切错误。
4. 有系统之外的软件或者硬件引起的软件不正常工作,认定为异常。
那么到底如何使用异常才算正确使用异常呢?要想弄清楚这个问题首先要弄清楚什么是异常。人们常常将异常和错误混为一谈,其实有着本质的区别:异常是由于过程的前置条件不满足而导致过程无法输出正确的结果;而错误是前置条件满足的情况下过程不能输出正确的结果或无法满足后置条件。异常是一个相对的概念,它是相对于一个过程的。一个异常对于一个过程本身是异常,对于其上层就不一定了。有一个例子先不看功能:
int div(int a,int b)
{
return a/b;
}
}
void funcation(int value)
{
int r[100];
for (int I = 100;i<=0;i--)
{
r[i] = div(value,i);
}
}
。。。
}
函数div是做a和b的除法,显然b不能为零。这是div的前置条件。当i= 0时div无法输出正确的值,所以这对于div来说是一个异常。但是对于function来说就不一样了。无论输入什么值,都无法改变其错误结果。也就是说导致div异常的原因和funtion的输入无关。那么对于Funcation来说就是一个错误。至于是编程错误还是设计错误甚至是需求错误那就不一定了。
总之
funcation
不能将0
作为被除数带入div
。除非div
的输入和funcation
的输入有关。
未完待续。。。
C++
异常处理机制的优点。
举例说明。