当unix出错时,经常返回一个负值,而且整形变量erron通常被设置为含有附加信息的一个值。例如open函数如果成功执行则
返回一个非负的的文件描述符。如果出错则返回-1。
在open出错时,大约有15钟不同的errno值。
有些函数以另一种形式返回。
多个线程共享进程地址空间,每个线程都有属于自己的局部erron以避免一个线程干扰另一线程。 linux支持多线程存取errno,
c标准定义了两个函数,
#include <string.h>
char *strerror(int errnum);
将出错号映射为出错信心字符串,并返回此字符串的指针。
perror函数是基于errno当前值, 产生一条出错信息。
#include<stdio.h>
void perror(const char* msg);
请看下面例子
#include"apue.h"
#include <errno.h>
int main(int argc,char** argv)
{
fprintf(stderr,"eacces:%s\n",strerror(EACCES));
errno=ENOENT;
PERROR(argv[0]);
exit(0);
}
出错恢复:出错分为两种:致命性的和非致命的。致命性的就是打印错误,无法恢复等

本文深入探讨Unix中错误处理机制,重点介绍errno及其在open函数中的应用,同时阐述了如何利用strerror和perror函数解析错误代码。此外,文章还提到了多线程环境下errno的管理与使用。
1万+

被折叠的 条评论
为什么被折叠?



