分类: LINUX
2013-09-29 15:07:27
以下是测试程序:
输入一个存在的文件名,如:./a.out 111
open失败则会输出:
perror: No such file or directory
strerror: Cannot allocate memory
open成功则会输出:
perror: Success
strerror: Permission denied
FROM:http://blog.sina.com.cn/s/blog_706211f30100punq.html
错误处理函数(3)
ferror: 检查文件流是否有错误发生
头文件: stdio.h
函数定义: int ferror(FILE *stream);
说明: ferror()用来检查参数stream所指定的文件流是否发生了错误情况, 若有则返回非0值.
perror: 打印出错误原因信息字符串
头文件: stdio.h
函数定义: void perror(const char *s);
说明: perror()用来将上一个函数发生错误的原因输出到标准错误(stderr). 参数s所指的字符串会先打印出, 后面加上错误的原因字符串. 此错误原因依照全局变量errno的来决定要输出的字符串.
应用举例:
#include
int main(void)
{
FILE *fp;
fp = fopen("/tmp/fdsafda", "r+");
if(fp == NULL)
{
perror("fopen");
}
return 0;
}
运行结果:
fopen: No such file or directory
strerror: 返回错误原因的描述字符串
头文件: string.h
函数定义: char *strerror(int errnum);
说明: strerror()用来依参数errnum的错误代码来查询错误原因的描述字符串, 然后将该字符串指针返回. 通常给其传递全局变量errno.
应用举例:
#include
#include
int main(void)
{
char *buffer;
buffer = strerror(errno);
printf("Error: %s\n", buffer);
return 0;
}
运行结果:
Error: Success
clearerr()函数,清除流中的结束指示符和错误指示符,void clearerr(FILE *fp) 用于清除与fp相关文件结束指示符和错误指示符
feof() 函数,int feof(FILE *FP)当与fp流相关的文件结束指示符被设置时,feof函数返回一个非零值
ferror() 函数,int ferror 当与流相关文件出错指示符被设置时,函数返回一个非零值
perror()函数,void perror(const char *str)用来输入字符串s以及与全局变量errno中的整数值相对应的出错信息,具体出错信息的内容依赖于实现
errno函数:头文件errno.h中定义了一个全局变量errno,底层库会自动记录函数运行后的状态(包括将错误码赋给errno),errno正值表明运 行正常,负值表明错误的类型,需要注意的是,errno不需要在外部申明,并且有时候errno=-1并不表明出现了错误,所以最好需要检测的函数被钓友 之前对其进行置零错左
errno在标准c库中只有两个错误值,EDOM 域错误,ERANGE 得到的结果越界
assert宏的原型定义在
FILE
*fp;
fp = fopen(
"test.txt", "w" );//以可写的方式打开一个文件,如果不存在就创建一个同名文件
assert( fp
); //所以这里不会出错
fclose( fp
);
fp = fopen(
"noexitfile.txt", "r" );//以只读的方式打开一个文件,如果不存在就打开文件失败
assert( fp
); //所以这里出错
fclose( fp
); //程序永远都执行不到这里来
return
0;
}
[root@localhost error_process]# gcc badptr.c
[root@localhost error_process]# ./a.out
a.out: badptr.c:14: main: Assertion `fp' failed.
已放弃
使用assert的缺点是,频繁的调用会极大的影响程序的性能,增加额外的开销。
在调试结束后,可以通过在包含#include
#include
#define NDEBUG
#include
用法总结与注意事项:
1)在函数开始处检验传入参数的合法性
如:
int resetBufferSize(int nNewSize)
{
//功能:改变缓冲区大小,
//参数:nNewSize 缓冲区新长度
//返回值:缓冲区当前长度
//说明:保持原信息内容不变 nNewSize<=0表示清除缓冲区
assert(nNewSize >= 0);
assert(nNewSize <=
MAX_BUFFER_SIZE);
...
}
2)每个assert只检验一个条件,因为同时检验多个条件时,如果断言失败,无法直观的判断是哪个条件失败
不好: assert(nOffset>=0
&&
nOffset+nSize<=m_nInfomationSize);
好: assert(nOffset >= 0);
assert(nOffset+nSize <=
m_nInfomationSize);
3)不能使用改变环境的语句,因为assert只在DEBUG个生效,如果这么做,会使用程序在真正运行时遇到问题
错误: assert(i++ < 100)
这是因为如果出错,比如在执行之前i=100,那么这条语句就不会执行,那么i++这条命令就没有执行。
正确: assert(i < 100)
i++;
4)assert和后面的语句应空一行,以形成逻辑和视觉上的一致感
5)有的地方,assert不能代替条件过滤