pid_tfork(void);//創(chuàng)建子進程成功時,向子進程返回0,并將子進程的進程ID返回給父進程//創(chuàng)建失敗時,返回-1,并將errno設置為EAGAIN返回值是允許父進程和子進程區(qū)別自己并執(zhí)行不同代碼的關(guān)鍵特征。#include

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Linux學習筆記12——Unix中的進程

系統(tǒng) 2455 0

  通過調(diào)用fork和exec函數(shù)都能創(chuàng)建新的進程,但兩者有著本質(zhì)的區(qū)別:fork函數(shù)拷貝了父進程的內(nèi)存映像,而exec函數(shù)用用新的映像來覆蓋調(diào)用進程的進程映像的功能。

一? fork函數(shù)

#include <unistd.h>

    pid_t fork(void);     //創(chuàng)建子進程成功時,向子進程返回0,并將子進程的進程ID返回給父進程

               //創(chuàng)建失敗時,返回-1,并將errno設置為EAGAIN

    返回值是允許父進程和子進程區(qū)別自己并執(zhí)行不同代碼的關(guān)鍵特征。

      #include <stdio.h>
      
        

#include 
      
      <unistd.h>
      
        

#include 
      
      <sys/types.h>




      
        int
      
       main(
      
        void
      
      
        ){

  pid_t childpid;                     
        
          //子進程的ID
        
        

  childpid
      
      =
      
        fork();                   
        
           //創(chuàng)建子進程 
        
      
      
        if
      
      (childpid==-
      
        1
      
      
        ){ ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 
        
          //創(chuàng)建子進程失敗
        
        

    perror(
      
      
        "
      
      
        Failed to fork
      
      
        "
      
      
        );

    
      
      
        return
      
      
        1
      
      
        ;

  }

  
      
      
        if
      
      (childpid==
      
        0
      
      
        ){ ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
        
          //創(chuàng)建子進程成功
        
        

    printf(
      
      
        "
      
      
        I am child %ld\n
      
      
        "
      
      ,(
      
        long
      
      
        )getpid()); ? ? ?
        
          //打印子進程的ID
        
        

  }

  
      
      
        else
      
      
        {

    printf(
      
      
        "
      
      
        I am parent %ld\n
      
      
        "
      
      ,(
      
        long
      
      
        )getpid()); ? ? 
        
          //打印父進程的ID
        
        

  }   

}
      
    

?

二 exec函數(shù)

  有六種不同形式的exec函數(shù),如下:

      #include <unistd.h>




      
        int
      
       execl(
      
        const
      
      
        char
      
       *path,                  ? ? 
      
        //進程映像文件的路徑名,可以是全限定路徑名,也可以是相對于當前目錄的路徑名
      
      
      const char *arg,... );                int execle( const char *path, const char *arg,..., char *const envp[] ); ? ? //最后一個參數(shù)必須以空指針(NULL)作結(jié)束 int execlp( const char *file, const char *arg,... ); int execv( const char *path,
char * const argv[]);         //參數(shù)數(shù)組,用來存放指向你的字符串參數(shù)的指針數(shù)組 int execve( const char *path, char * const argv[], char * const envp[]); int execvp( const char *file, char * const argv[]);

  execv開頭的函數(shù)是把參數(shù)以"char *argv[]"這樣的形式傳遞命令行參數(shù)。而execl開頭的函數(shù)采用了我們更容易習慣的方式,把參數(shù)一個一個列出來,然后以一個NULL

表示結(jié)束,也可以寫成(char *)0。

  如果創(chuàng)建子進程不成功,所有的exec函數(shù)都返回-1,并設置errno,以下是errno的類型和原因。

  E2BIG:新進程的參數(shù)表和環(huán)境表長度以系統(tǒng)所允許的ARG_MAX字節(jié)的限制要長

  EACCES:對新進程路徑前綴中目錄的搜尋權(quán)限被否定,新進程映像文件的執(zhí)行權(quán)限被否定,或者新進程映像文件不是正常的文件,且不能被執(zhí)行

  EINVAL:新進程映像文件有恰當?shù)臋?quán)限,且以可識別可執(zhí)行的二進制格式出現(xiàn)

  ELOOP:在對參數(shù)path或file進行解析時存在循環(huán)

  ENAMETOOLONG:path或file的長度超出了PATH_MAX的范圍,或者路徑名組件比NAME_MAX要長

  ENOENT:path或file組件命名的不是一個現(xiàn)存的文件,或者path或file為空字符串

  ENOEXEC:映像文件有恰當?shù)脑L問權(quán)限,但它的格式不可識別(不適用于execlp或execvp)

  ENOTDIR:映像文件路徑前綴的組件不是一個目錄

      
             int
      
       main(
      
        int
      
       argc,
      
        char
      
       *argv[],
      
        char
      
       *
      
        envp[])

        {

             
      
      
        char
      
       *arg[]={
      
        "
      
      
        ls
      
      
        "
      
      ,
      
        "
      
      
        -a
      
      
        "
      
      
        ,NULL};

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execl...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execl(
      
        "
      
      
        /bin/ls
      
      
        "
      
      ,
      
        "
      
      
        ls
      
      
        "
      
      ,
      
        "
      
      
        -a
      
      
        "
      
      ,NULL)<
      
        0
      
      
        )

                 {

                      fprintf(stderr,
      
      
        "
      
      
        execl failed:%s
      
      
        "
      
      
        ,strerror(errno));

                      
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execv...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execv(
      
        "
      
      
        /bin/ls
      
      
        "
      
      ,arg)<
      
        0
      
      
        )

                 {

                     fprintf(stderr,
      
      
        "
      
      
        execl failed:%s\n
      
      
        "
      
      
        ,strerror(errno));

                     
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execlp...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execlp(
      
        "
      
      
        ls
      
      
        "
      
      ,
      
        "
      
      
        ls
      
      
        "
      
      ,
      
        "
      
      
        -a
      
      
        "
      
      ,NULL)<
      
        0
      
      
        )

                 {

                     fprintf(stderr,
      
      
        "
      
      
        execl failed:%s
      
      
        "
      
      
        ,strerror(errno));

                     
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execvp...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execvp(
      
        "
      
      
        ls
      
      
        "
      
      ,arg)<
      
        0
      
      
        )

                 {

                     fprintf(stderr,
      
      
        "
      
      
        execl failed:%s\n
      
      
        "
      
      
        ,strerror(errno));

                     
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execle...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execle(
      
        "
      
      
        /bin/ls
      
      
        "
      
      ,
      
        "
      
      
        ls
      
      
        "
      
      ,
      
        "
      
      
        -a
      
      
        "
      
      ,NULL,envp)<
      
        0
      
      
        )

                 {

                     fprintf(stderr,
      
      
        "
      
      
        execl failed:%s
      
      
        "
      
      
        ,strerror(errno));

                     
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }

             
      
      
        if
      
      (fork()==
      
        0
      
      
        )

             {

                 printf(
      
      
        "
      
      
        execve...........\n
      
      
        "
      
      
        );

                 
      
      
        if
      
      (execve(
      
        "
      
      
        /bin/ls
      
      
        "
      
      ,arg,envp)<
      
        0
      
      
        )

                 {

                     fprintf(stderr,
      
      
        "
      
      
        execl failed:%s\n
      
      
        "
      
      
        ,strerror(errno));

                     
      
      
        return
      
       -
      
        1
      
      
        ;

                 }

             }



          
      
      
        return
      
      
        0
      
      
        ;

        }
      
    

?

?

Linux學習筆記12——Unix中的進程


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 久久精品一区 | 污视频在线网站 | 久久午夜夜伦伦鲁鲁片 | 久久精品免视看国产陈冠希 | 拍真实国产伦偷精品 | 成年女人免费毛片视频永久 | 免费在线中文字幕 | 久久久噜噜噜 | 第一国内永久免费福利视频 | 伊人一区二区三区 | 超级97碰碰碰碰久久久久最新 | 嫩模尺度私拍在线视频 | 亚洲精品成人 | 久久综合99 | 欧美三级午夜理伦三级小说 | 亚洲综合首页 | 日本久久免费 | 国产美女福利视频 | 亚洲视频综合 | 精品在线观看一区 | 国产线路一 | 97激情 | 久久免费观看爱情动作片 | 深夜在线免费观看 | 国产成人精品综合网站 | 久久一本久综合久久爱 | 一级特黄特黄的大片免费 | 一本大道加勒比久久综合 | 护士日本xxxxx丰满hd4k | 精品一区二区久久久久久久网站 | 欧美黑大粗硬毛片视频 | 欧美成人a级在线视频 | 亚洲成片观看四虎永久 | 日本免费一区二区久久人人澡 | 国产成人精品日本亚洲语音2 | 精品99视频 | 久久国产视频在线观看 | 国产精品久久久久久久久kt | 无毒不卡 | 91精品久久 | 国产亚洲在线观看 |