按照 ISO C 的规定,一个进程可以登记多达 32 个函数,这些函数将由 exit
自动调用。我们称这些函数为终止处理函数 (exit handler),并调用 atexit
函数来登记这些函数。
#include <stdlib.h>
int atexit(void (*func)(void));
返回值:若成功则返回 0,或出错则返回非 0 值
其中,atexit
的参数是一个函数地址,当调用此函数时无需向它传送任何函数,也不期望它返回一个值。exit
调用这些函数的顺序与它们登记时候的顺序相反。同一函数如若被登记多次,则也会被调用多次。
atexit.c
#include <stdlib.h>
/* external declarations */
extern void (*_Atfuns[])(void);
extern size_t _Atcount;
int (atexit)(void (*func)(void)) /* function to call at exit */
{
if (_Atcount == 0)
return (-1);
_Atfuns[--_Atcount] = func; /* list is full */
return (0);
}
exit.c
#include <stdio.h>
#include <stdlib.h>
/* macros */
#define NATS 32
/* static data */
void (*_Atfuns[NATS])(void) = {0};
size_t _Atcount = {NATS};
void (exit)(int status) /* tidy up and exit to system */
{
while (_Atcount < NATS) {
(*_Atfuns[_Atcount++])() ;
}
size_t ;
for (i = 0; i < FOPEN_MAX; ++i) /* close all files */
if (_Files[i])
fclose(_Files[i]);
_Exit (status);
}
参考资料
[1] C 标准库.卢红星等译.人民邮电出版社
[2] UNIX 环境高级编程第 2 版.尤晋元等译.人民邮电出版社