©
本文檔使用 php中文網手册 發布
在头文件<stdlib.h>中定义 | ||
---|---|---|
void exit(int exit_code); | (直到C11) | |
_Noreturn void exit(int exit_code); | (自C11以来) |
导致正常程序终止发生。
执行几个清理步骤:
传递给atexit的函数被调用,按照注册的相反顺序
所有C流都被刷新并关闭
由tmpfile创建的文件被删除
控制权返回到主机环境。 如果exit_code为零或EXIT_SUCCESS,则返回实现定义的状态,表示成功终止。 如果exit_code为EXIT_FAILURE,则返回实现定义的状态,表示不成功终止。 在其他情况下,返回实现定义的状态值。
用at_quick_exit注册的函数不会被调用。
如果一个程序多次调用exit或者调用exit和quick_exit,则行为是不确定的。
如果在调用使用atexit注册的函数期间,行为是不确定的,函数将以longjmp退出。
从主函数返回,通过返回语句或到达函数结尾,执行exit(),将return语句的参数(如果使用隐式返回,则返回0)作为exit_code。
exit_code | - | 退出程序的状态 |
---|
(none).
#include <stdio.h>#include <stdlib.h> int main(void){ FILE *fp = fopen("data.txt","r"); if (fp == NULL) { fprintf(stderr, "error opening file data.txt in function main()\n"); exit(1); } fclose(fp); printf("Normal Return\n");}
输出:
error opening file data.txt in function main()
C11标准(ISO / IEC 9899:2011):
7.22.4.4退出功能(p:351-352)
C99标准(ISO / IEC 9899:1999):
7.20.4.3退出功能(p:315-316)
C89 / C90标准(ISO / IEC 9899:1990):
4.10.4.3退出功能
abort | 导致程序异常终止(不清除)(功能) |
---|---|
atexit | 注册要在exit()调用(函数)上调用的函数 |
quick_exit(C11) | 导致正常程序终止而没有完全清理(功能) |
| 用于退出的C ++文档|