<listing id="62mou"><object id="62mou"></object></listing>
    <output id="62mou"><pre id="62mou"><dd id="62mou"></dd></pre></output>
  1. 新闻?#34892;?/h2>

    EEPW首页 > 嵌入式系统 > 设计应用 > Linux进程几种退出方式的比较

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

    作者:时间:2018-10-10来源?#21644;?#32476;收藏

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

    本文引用地址:http://www.09140960.com/article/201810/392683.htm

      进程退出

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

      1.正常退出

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

      b.调用exit()函数

      c.调用_exit()函数

      2.异常退出

      a.调用about函数

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

      不管是哪种退出方式,系统最终都会执行内核中的同一代码。这段代码用来关闭进程所用已打开的文件描述符,释放它所占用的内存和其他资源。

      几种退出方式的比较

      1.exit和return ?#37027;?#21035;

      exit是一个函数,有?#38382;xit执行完后把控制权交给系统。

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

      2.exit和abort?#37027;?#21035;

      exit是正常终止进程。

      about是异常终止。

      exit()和_exit()函数

      exit和_exit函数都是用来终止进程的。当程序执行到exit或_exit时,系统无条件的停止剩下所有操作,清除各种数据结构,并终止本进程的运行。

      exit在头文件stdlib.h中声明,而_exit()声明在头文件unistd.h中声明。 exit中的?#38382;齟xit_code为0代表进程正常终止,若为其他?#24403;?#31034;程序执行过程中?#20889;?#35823;发生。

      exit()和_exit()?#37027;?#21035;

      _exit()执行后立即返回给内核,而exit()要先执行一些清除操作,然后将控制权交给内核。

      调用_exit函数时,其会关闭进程所有的文件描述符,清理内存以及其他一些内核清理函数,但不会刷新流(stdin, stdout, stderr ...). exit函数是在_exit函数之上的一个封装,其会调用_exit,并在调用之前?#20154;?#26032;流。

      exit()函数与_exit()函数最大区别就在于exit()函数在调用exit系统之前要检查文件的打开情况,把文件缓冲区的内容写回文件。由于的标准函数库中,有一种被称作“缓冲I/O”的操作,其特征就?#23884;?#24212;每一个打开的文件,在内存中都有一片缓冲区。

      每次读文件时,会连续的读出若?#21830;?#35760;录,这样在下次读文件时就可以直接从内存的缓冲区读取;同样,每次写文件的时候?#27493;?#20165;是写入内存的缓冲区,等满足了一定的条件(如达到了一定数量或遇到特定?#22336;?#31561;),再将缓冲区中的内容一次性写入文件。

      这种技术大大增加了文件读写的速度,但也给编程代来了一点儿麻烦。比如有一些数据,认为已经写入了文件,?#23548;?#19978;因为没?#26032;?#36275;特定的条件,它们还只是保存在缓冲区内,这时用_exit()函数直接将进程关闭,缓冲区的数据就会丢失。因此,要想保证数据的完整性,就一定要使用exit()函数。

      通过一个函数实例来看看它们之间?#37027;?#21035;:

      函数实例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?#34987;?#34892;符时自动的从缓冲区中将记录读出。所以exit()将缓冲区的数据写完后才退出,而_exit()函数直接退出。

      大家?#37096;?#20197;把函数实例2中的printf("This is the content in buffer");改为printf("This is the content in buffer\n")(即在printf中最后加一个\n看运行结果是什么,为什么会产生这样的结果呢?)

      父子进程终止的先后顺序不同会产生不同的结果

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

      此种情况就是我们前面所用的孤儿进程。当父进程先退出时,系统会让init进程接管子进程 。

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

      此种情况子进程进入僵死状态,并?#19968;?#19968;直保持下去直到系统重启。子进程处于僵死状态时,内核只保存进程的一些必要信息以备父进程所需。此时子进程始终占有着资源,同时也减少了系统可?#28304;?#24314;的最大进程数。

      什么是 僵死状态呢?一个已经终止、但是其父进程尚未对其进行善后处理(获取终止子进程的有关信息,释放它仍占有的资源)的进程被称为僵死进程(zombie)。

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

      此时父进程会等待子进程结束。



    关键?#21097;? Linux

    评论


    技术专区

    关闭
    贵州11选5app下载
      <listing id="62mou"><object id="62mou"></object></listing>
      <output id="62mou"><pre id="62mou"><dd id="62mou"></dd></pre></output>
      1. <listing id="62mou"><object id="62mou"></object></listing>
        <output id="62mou"><pre id="62mou"><dd id="62mou"></dd></pre></output>
      2. pk10冠军百期错一 建彩票网站合法吗 快中彩开奖号码 江苏11选5一天开多少期 足彩比分 广西快乐十分开奖规则 六合图库黑白 3d晚秋历史记录2019 宝盈娱乐平台 彩票极速飞艇计划软件 内蒙古十一选五的走势图百度乐彩网 内蒙古福彩中心地址 qq欢乐升级塞班 六六文章白小姐 福利彩票福建时时彩走势图