UNIX 编程中 errno 变量的使用与错误处理
在 UNIX C/C++ 编程中, errno
变量是处理错误的关键元素。随着 UNIX 平台的发展,尤其是对线程支持的引入, errno
变量的声明和使用发生了一些变化。本文将详细介绍这些变化,以及如何正确使用 errno
变量来处理和报告错误。
1. errno
变量的声明变化
现代 UNIX 平台为了支持线程,对底层 C 库和 errno
变量的定义进行了内部更改。线程是在一个内存环境中的独立指令流,所有线程共享一个内存地址空间。传统的单一全局整数 errno
值不再适用,因为一个线程中的函数调用可能会改变另一个线程引用的 errno
值。
为了在不重新设计现有软件的情况下支持线程,为 errno
值创建了一个新的声明(通常是一个 C 宏)。这个新定义为每个线程定义了一个单独的 errno
副本。现在,不需要程序员手动声明这个变量,而是通过包含 <errno.h>
文件来让系统为你定义。
// 新的 errno 声明方式
#include <errno.h>
// 不需要再手动声明 extern int errno;