C++官网参考链接:https://cplusplus.com/reference/cstdlib/atexit/
函数
<cstdlib>
atexit
C
int atexit (void (*func)(void));
C++98
extern "C" int atexit (void (*func)(void));
extern "C++" int atexit (void (*func)(void));
C++11
extern "C" int atexit (void (*func)(void)) noexcept;
extern "C++" int atexit (void (*func)(void)) noexcept;
设置函数在退出时执行
func所指向的函数在程序正常终止时不带实参自动调用。
如果对该函数的不同调用指定了多个atexit函数,它们将以堆栈的相反顺序执行(即,指定的最后一个函数是在退出时第一个执行的函数)。
可以注册一个函数,以便在退出时执行多次。
如果在exit之后调用atexit,则调用可能成功,也可能失败,这取决于特定的系统和库实现(未指定的行为)。
如果用atexit注册的函数在终止调用时抛出异常,它没有为该异常提供处理程序,则自动调用terminate(C++)。
特定的库实现可能会对可以注册到atexit的函数调用的数量施加限制,但这不能少于32个函数调用。
形参
func
被调用的函数。函数不返回任何值,也不接受任何实参。
返回值
如果函数成功注册,则返回0值。
如果失败,则返回非0值。
用例
/* atexit example */
#include <stdio.h> /* puts */
#include <stdlib.h> /* atexit */
void fnExit1 (void)
{
puts ("Exit function 1.");
}
void fnExit2 (void)
{
puts ("Exit function 2.");
}
int main ()
{
atexit (fnExit1);
atexit (fnExit2);
puts ("Main function.");
return 0;
}
输出:
数据竞争
同时调用此函数不会引入数据竞争(C++):调用在进程级别上正确地同步。
异常(C++)
无抛出保证:此函数从不抛出异常。