您的位置 首页 被动

Linux进程几种退出方法的比较

导语:当一个进程结束了运行或在半途中终止了运行,那么内核就需要释放该进程所占用的系统资源。这包括进程运行时打开的文件,申请的内存等。进程退出Linux 下进程的退出分为正常退出和异常退出两

  导语:当一个进程完毕了运转或在半途中中止了运转,那么内核就需要开释该进程所占用的体系资源。这包含进程运转时翻开的文件,请求的内存等。

  进程退出

  Linux 下进程的退出分为正常退出和反常退出两种:

  1.正常退出

  a. 在main()函数中履行return

  b.调用exit()函数

  c.调用_exit()函数

  2.反常退出

  a.调用about函数

  b.进程收到某个信号,而该信号使程序中止

  不管是哪种退出方法,体系终究都会履行内核中的同一代码。这段代码用来封闭进程所用已翻开的文件描述符,开释它所占用的内存和其他资源。

  几种退出方法的比较

  1.exit和return 的差异

  exit是一个函数,有参数。exit履行完后把控制权交给体系。

  return是函数履行完后的回来,renturn履行完后把控制权交给调用函数。

  2.exit和abort的差异

  exit是正常中止进程。

  about是反常中止。

  exit()和_exit()函数

  exit和_exit函数都是用来中止进程的。当程序履行到exit或_exit时,体系无条件的中止剩余一切操作,铲除各种数据结构,并中止本进程的运转。

  exit在头文件stdlib.h中声明,而_exit()声明在头文件unistd.h中声明。 exit中的参数exit_code为0代表进程正常中止,若为其他值表明程序履行进程中有过错发生。

  exit()和_exit()的差异

  _exit()履行后当即回来给内核,而exit()要先履行一些铲除操作,然后将控制权交给内核。

  调用_exit函数时,其会封闭进程一切的文件描述符,整理内存以及其他一些内核整理函数,但不会改写流(stdin, stdout, stderr …). exit函数是在_exit函数之上的一个封装,其会调用_exit,并在调用之前先改写流。

  exit()函数与_exit()函数最大差异就在于exit()函数在调用exit体系之前要查看文件的翻开状况,把文件缓冲区的内容写回文件。由于Linux的规范函数库中,有一种被称作“缓冲I/O”的操作,其特征便是对应每一个翻开的文件,在内存中都有一片缓冲区。

  每次读文件时,会接连的读出若干条记载,这样在下次读文件时就能够直接从内存的缓冲区读取;相同,每次写文件的时分也仅仅是写入内存的缓冲区,等满意了必定的条件(如达到了必定数量或遇到特定字符等),再将缓冲区中的内容一次性写入文件。

  这种技能大大增加了文件读写的速度,但也给编程代来了一点儿费事。比方有一些数据,以为现已写入了文件,实际上由于没有满意特定的条件,它们还仅仅保存在缓冲区内,这时用_exit()函数直接将进程封闭,缓冲区的数据就会丢掉。因而,要想确保数据的完整性,就必定要运用exit()函数。

  经过一个函数实例来看看它们之间的差异:

  函数实例1: exit.c

  #include

  #include

  int main()

  {

  printf("using exit—-\n");

  printf("This is the content in buffer\n");

  exit(0);

  }

  履行成果为:

  using exit—-

  This is the content in buffer

  函数实例2:_exit.c

  #include

  #include

  int main()

  {

  printf("using _exit–\n");

  printf("This is the content in buffer");

  _exit(0);

  }

  履行成果为 :

  using _exit–

  printf函数便是运用缓冲I/O的方法,该函数在遇到“\n”换行符时主动的从缓冲区中将记载读出。所以exit()将缓冲区的数据写完后才退出,而_exit()函数直接退出。

  咱们也能够把函数实例2中的printf("This is the content in buffer");改为printf("This is the content in buffer\n")(即在printf中最终加一个\n看运转成果是什么,为什么会发生这样的成果呢?)

  父子进程中止的先后顺序不同会发生不同的成果

  1.父进程先于子进程中止

  此种状况便是咱们前面所用的孤儿进程。当父进程先退出时,体系会让init进程接管子进程 。

  2.子进程先于父进程中止,而父进程又没有调用wait函数

  此种状况子进程进入僵死状况,并且会一向坚持下去直到体系重启。子进程处于僵死状况时,内核只保存进程的一些必要信息以备父进程所需。此刻子进程一直占有着资源,一起也减少了体系能够创立的最大进程数。

  什么是 僵死状况呢?一个现已中止、可是其父进程没有对其进行善后处理(获取中止子进程的有关信息,开释它仍占有的资源)的进程被称为僵死进程(zombie)。

  3.子进程先于父进程中止,而父进程调用了wait函数

  此刻父进程会等候子进程完毕。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ziliao/beidong/131433.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部