linux c中return 与exit的区别
来源:互联网 发布:寻仙linux服务端 编辑:程序博客网 时间:2024/06/04 01:15
1.
return 是c语言中的关键字,而exit是linux中的系统调用。
return是表示函数的返回,而exit是进程的终止。
如果return 或者exit出现在main函数中,两者的作用是一样。
如果return出现在子程序中表示返回,而exit出现在子进程中表示终止子进程。
2.
通常情况:exit(0)表示程序正常, exit(1)/exit(-1)表示程序异常退出,exit(2)表示表示系统找不到指定的文件。用Error lookup可以查看
exit()结束当前进程/当前程序/,在整个程序中,只要调用exit就结束(当前进程或者在main时候为整个程序)
return()是当前函数返回,当然如果是在主函数main, 自然也就结束当前进程了,如果不是,那就是退回上一层调用。在多个进程时.如果有时要检测上进程是否正常退出的.就要用到上个进程的返回值,依次类推。
exit(1)表示进程非正常退出. 返回1;
exit(0)表示进程正常退出. 返回0.
进程环境与进程控制(1): 进程的开始与终止
exit(int n)其实就是直接退出程序,因为默认的标准程序入口为 int main(int argc, char** argv),返回值是int型的。一般在shell下面,运行一个程序,然后使用命令echo $?就能得到该程序的返回值,也就是退出值,在main()里面,你可以用return n,也能够直接用exit(n)来做。unix默认的习惯正确退出是返回0,错误返回非0。
理论上exit可以返回小于256的任何整数。返回的不同数值主要是给调用者作不同处理的。
单独的进程是返回给操作系统的。如果是多进程,是返回给父进程的。父进程里面调用waitpid()等函数得到子进程退出的状态,以便作不同处理。根据相应的返回值来让调用者作出相应的处理.总的说来,exit()就是当前进程把控制权返回给调用该程序的程序,括号里的是返回值,告诉调用程序该程序的运行状态
1. 进程的开始:
C程序是从main函数开始执行, 原型如下:
int main(int argc, char *argv[]);
通常main的返回值是int型, 正确返回0.
如果main的返回值为void或者无, 某些编译器会给出警告, 此时main的返回值通常是0.(看我blog下面关于return函数的介绍就知道,事实上main函数是没有void main()这样的声明的,一定要在main的结束有返回值,需要返回什么类型的值,就返回这个类型的值。通常为int型的0值表示成功返回)
关于main的命令行参数不做过多解释, 以下面的程序展示一下:
- #include <stdio.h>
- int main(int argc, char *argv[])
- {
- int i;
- for (i = 0; i < argc; i++)
- printf("argv[%d]: %s/n", i, argv[i]);
- return 0;
- }
2. 进程终止:
C程序的终止分为两种: 正常终止和异常终止.
正常终止分为: return, exit, _exit, _Exit, pthreade_exit
异常中指分为: abort, SIGNAL, 线程响应取消
主要说一下正常终止的前4种, 即exit系列函数.
#include <stdlib.h> /* ISO C */
void exit(int status);
void _Exit(int status);
#include <unistd.h> /* POSIX */
void _exit(int status);
以上3个函数的区别是:
exit()(或return 0)会调用终止处理程序和用户空间的标准I/O清理程序(如fclose), _exit和_Exit不调用而直接由内核接管进行清理.因此, 在main函数中exit(0)等价于return 0.
_exit()函数的作用最为简单:直接使进程停止运行,清除其使用的内存空间,并销毁其在内核中的各种数据结构;exit()函数则在这些基础上作了一些包装,在执行退出之前加了若干道工序,也是因为这个原因,有些人认为exit已经不能算是纯粹的系统调用。
exit()函数与_exit()函数最大的区别就在于exit()函数在调用exit系统调用之前要检查文件的打开情况,把文件缓冲区中的内容写回文件,就是图中的“清理I/O缓冲”一项。
在Linux 的标准函数库中,有一套称作“高级I/O”的函数,我们熟知的printf()、fopen()、fread()、fwrite()都在此列,它们也被称作“缓冲I/O(buffered I/O)”,其特征是对应每一个打开的文件,在内存中都有一片缓冲区,每次读文件时,会多读出若干条记录,这样下次读文件时就可以直接从内存的缓冲区中读取,每次写文件的时候,也仅仅是写入内存中的缓冲区,等满足了一定的条件(达到一定数量,或遇到特定字符,如换行符/n和文件结束符EOF),再将缓冲区中的内容一次性写入文件,这样就大大增加了文件读写的速度,但也为我们编程带来了一点点麻烦。如果有一些数据,我们认为已经写入了文件,实际上因为没有满足特定的条件,它们还只是保存在缓冲区内,这时我们用_exit()函数直接将进程关闭,缓冲区中的数据就会丢失,反之,如果想保证数据的完整性,就一定要使用exit()函数。
请看以下例程:
/* exit2.c */
#include<stdlib.h>
- int main()
- {
- printf("output begin/n");
- printf("content in buffer");
- exit(0);
- }
编译并运行:
$gcc exit2.c -o exit2
$./exit2
output begin
content in buffer
/* _exit1.c */
- #include<unistd.h>
- int main()
- }
- printf("output begin/n");
- printf("content in buffer");
- _exit(0);
- }
编译并运行:
$gcc _exit1.c -o _exit1
$./_exit1
output begin
3. atexit终止处理程序:
ISO C规定, 一个进程最对可登记32个终止处理函数, 这些函数由exit按登记相反的顺序自动调用. 如果同一函数登记多次, 也会被调用多次.
原型如下:
#include <stdlib.h>
int atexit(void (*func)(void));
其中参数是一个函数指针, 指向终止处理函数, 该函数无参无返回值. atexit函数本身成功调用后返回0.
以下面的程序为例:
- #include <stdlib.h>
- static void myexit1()
- {
- printf("first exit handler/n");
- }
- static void myexit2()
- {
- printf("second exit handler/n");
- }
- int main()
- {
- if (atexit(my_exit2) != 0)
- printf("can't register my_exit2/n");
- if (atexit(my_exit1) != 0)
- printf("can't register my_exit1/n");
- if (atexit(my_exit1) != 0)
- printf("can't register my_exit1/n");
- printf("main is done/n");
- return 0;
- }
运行结果:
$ ./a.out
main is done
first exit handler
first exit handler
second exit handler运行结果:
注意上面的结果,可以发现这些函数由exit按登记相反的顺序自动调用(先myexit1后myexit2). 如果同一函数登记多次, 也会被调用多次(如这里的myexit1).而这些处理函数都是在程序推出的时候利用atexit函数调用了这些处理函数。但是如果用_exit()退出程序,则它不关闭任何文件,不清除任何缓冲器、也不调用任何终止函数!
return函数exit函数区别
1,exit用于在程序运行的过程中随时结束程序,exit的参数是返回给OS的。main函数结束时也会隐式地调用exit函数。exit函数运行时首先会执行由atexit()函数登记的函数,然后会做一些自身的清理工作,同时刷新所有输出流、关闭所有打开的流并且关闭通过标准I/O函数tmpfile()创建的临时文件。exit是结束一个进程,它将删除进程使用的内存空间,同时把错误信息返回父进程,而return是返回函数值并退出函数
2,return是语言级别的,它表示了调用堆栈的返回;而exit是系统调用级别的,它表示了一个进程的结束。
3,exit函数是退出应用程序,并将应用程序的一个状态返回给OS,这个状态标识了应用程序的一些运行信息。
4,和机器和操作系统有关一般是 0 为正常退出 非0 为非正常退出
5,void exit(int status);
6,atexit()函数的参数是一个函数指针,函数指针指向一个没有参数也没有返回值的函数。atexit()的函数原型是:int atexit (void (*)(void));在一个程序中最多可以用atexit()注册32个处理函数,这些处理函数的调用顺序与其注册的顺序相反,也即最先注册的最后调用,最后注册的最先调用。
一般程序执行到 main() 的结束就完成了, 如果想在程序结束时做一些事情, 可以尝试着用这个函数.
example:
- void f1(void)
- {
- printf("exit f1/n");
- }
- void f2(void)
- {
- printf("exit f2/n");
- }
- int main()
- {
- atexit(f1);
- atexit(f2);
- printf("exit main/n");
- return 0;
- }
- linux c中return 与exit的区别
- c 中 exit 与 return 的区别
- linux 中 return 与exit的区别
- C语言中return,exit return exit的区别
- C语言中return,exit return exit的区别
- C语言中return,exit return exit的区别
- C语言中return与 exit的区别
- c语言中return与exit的区别
- c语言中return与exit的区别
- c语言中return与exit的区别
- c语言中return与exit 的区别
- C语言中exit()与return的区别
- c语言中return与exit的区别
- 知识点1:C语言中exit()与return的区别
- c中exit和return的区别
- exit 与 return 的区别
- return与exit的区别
- exit与return的区别
- Mat,CV::MAT,IplImage含义,区别及其转换
- jquery面向对象编程
- ThinkPHP 找不到index方法
- IE共享session解决方法
- myGeneration生成数据库说明文档
- linux c中return 与exit的区别
- makefile中使用环境变量的例子
- FLASH中注册点与中心点的区别
- Android下图片处理的的一些方法
- 使用call_usermodehelper在Linux内核中直接运行用户空间程序
- 测试URL有效性
- MySQL Cluster错误集锦(更新)
- XAMPP与VisualSVN,oracle共存
- Hibernate 使用createSQLQuery查询时,缓存问题