防御式编程
一 对输入进行体检
- 1 检查输入源(如:文件,网络、控制台等)数据的合法性
- 2 检查每一个函数输入参数的合法性
处理方式:一旦非法输入被发现,那么应该根据情况进行处理。防御式编程的最佳的形式是在一开始就不引入错误
二 对非预期错误使用断言
- 1 空指针
- 2 输入或者输出参数的值不在预期范围内
- 3 数组的越界
处理方式:如果断言的条件返回错误,则终止程序执行
#include <assert.h>
void assert( int expression );
assert的作用是先计算表达式expression,如果其值为假(即为0),那么它先向stderr打印一条出错信息,然后通过调用abort来终止程序运行
bool isPeak(int map[MAPMAX][MAPMAX], int i, int j)
{
assert(i > 1 && i < MAPMAX - 1);
assert(j > 1 && j < MAPMAX - 1);
if (map[i][j] > map[i - 1][j] &&
map[i][j] > map[i + 1][j] &&
map[i][j] > map[i][j + 1] &&
map[i][j] > map[i][j - 1]
)
{
return true;
}
else
{
return false;
}
}
在调用时,传参错误就会终止程序