exit
在头文件<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 ++文档|
本文档系腾讯云开发者社区成员共同维护,如有问题请联系 cloudcommunity@tencent.com

