现在的我,不埋怨谁,不嘲笑谁,也不羡慕谁。阳光下灿烂,风雨中奔跑,做自己的梦,走自己的路。一切都好,真的,都很好。
分类:
2012-05-22 16:07:55
exit函数在头文件stdlib.h中。
exit(0):正常运行程序并退出程序;
exit(1):非正常运行导致退出程序;
return():返回函数,若在main主函数中,则会退出函数并返回一值,可以写为return(0),或return 0。
详细说:
1. return返回函数值,是关键字;exit是一个函数。
2. return是语言级别的,它表示了调用堆栈的返回;而exit是系统调用级别的,它表示了一个进程的结束。
3. return是函数的退出(返回);exit是进程的退出。
4. return是C语言提供的,exit是操作系统提供的(或者函数库中给出的)。
5. return用于结束一个函数的执行,将函数的执行信息传出个其他调用函数使用;exit函数是退出应用程序,删除进程使用的内存空间,并将应用程序的一 个状态返回给OS,这个状态标识了应用程序的一些运行信息,这个信息和机器和操作系统有关,一般是 0 为正常退出,非0 为非正常退出。
6. 非主函数中调用return和exit效果很明显,但是在main函数中调用return和exit的现象就很模糊,多数情况下现象都是一致的。
下面是几个例子:
1.
#include #include #include int main(void) { pid_t pid; int count=0; pid=vfork(); if(pid==0) { printf("child: count=%d\n",count); printf("child: getpid=%d\n",getpid()); count=1; printf("child: count=%d\n",count); // return 0;//会出现段错误 exit(0); //ok } else { printf("\nfather: pid=%d\n",pid); printf("father: count=%d\n",count); } return(0); } |
运行结果
[root@localhost part1_linux]# gcc fork2.c [root@localhost part1_linux]# ./a.out child: count=0 child: getpid=9911 child: count=1 father: pid=9911 father: count=1 |
运行结果说明:vfrok时父、子进程共享数据段,fork时是进行拷贝。如果,vfork子进程中,使用return返回时,出现段错误,结果如下:
[root@localhost part1_linux]# gcc fork2.c [root@localhost part1_linux]# ./a.out child: count=0 child: getpid=10864 child: count=1 father: pid=10864 father: count=0 段错误 |
#include #include #include int main() { int i=0; pid_t pid; printf("还没创建子进程\n"); i++; pid = fork(); if(pid==-1) { printf("fork error!\n"); } else if(pid==0) { i++; printf("我是子进程,id%d\n",getpid()); printf("我的父亲是id:%d\n",getppid()); printf("-----i=%d-----\n",i); } else { i++; printf("我是父进程,id:%d\n",getpid()); printf("-----i=%d-----\n",i); } exit(0); } |