exec函數族

exec用被執行的程序完全替換調用它的程序的影像。fork創建一個新的進程就產生了一個新的PID,
exec啓動一個新程序,替換原有的進程,因此這個新的被exec執行的進程的PID不會改變,
和調用exec函數的進程一樣。
int   exec…裝入和運行其它程序:
int   execl(  char *pathname,char *arg0,char *arg1,...,char *argn,NULL)
int   execle( char *pathname,char *arg0,char *arg1,...,char *argn,NULL,char *envp[])
int   execlp( char *pathname,char *arg0,char *arg1,...,NULL)
int   execlpe(char *pathname,char *arg0,char *arg1,...,NULL,char *envp[])
int   execv(  char *pathname,char *argv[])
int   execve( char *pathname,char *argv[],char *envp[])
int   execvp( char *pathname,char *argv[])
int   execvpe(char *pathname,char *argv[],char *envp[])
         exec函數族裝入並運行程序pathname,並將參數
          arg0(arg1,arg2,argv[],envp[])傳遞給子程序,出錯返回-1
       在exec函數族中,後綴l、v、p、e添加到exec後,
       所指定的函數將具有某種操作能力
      有後綴  p時,函數可以利用DOS的PATH變量查找子程序文件。
假如你希望執行命令 /bin/cat /etc/passwd /etc/group,
    l時,希望接收以逗號分隔的參數列表,列表以NULL指針作爲結束標誌
        execl( "/bin/cat","/etc/passed","/etc/group",NULL);
    v時,希望接收到一個以NULL結尾的字符串數組的指針
        char* argv[] = {"/bin/cat","/etc/passed","/etc/group",NULL}
        execv( "/bin/cat", argv );
    e時,函數傳遞指定參數envp,允許改變子進程的環境,無後綴e時,子進程使用當前程序的環境。
        envp也是一個以NULL結尾的字符串數組指針
       
   
execl(執行文件)
相關函數
    fork,execle,execlp,execv,execve,execvp
表頭文件
    #include<unistd.h>
定義函數
    int execl(const char * path,const char * arg,....);
函數說明
    execl()用來執行參數path字符串所代表的文件路徑,接下來的參數代表執行該文件時傳遞過去的argv(0)、argv[1]……,最後一個參數必須用空指針(NULL)作結束。
返回值
    如果執行成功則函數不會返回,執行失敗則直接返回-1,失敗原因存於errno中。
範例
#include<unistd.h>
main()
{
execl(“/bin/ls”,”ls”,”-al”,”/etc/passwd”,(char * )0);
}

執行/*執行/bin/ls -al /etc/passwd */ 
   
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
 

   
execlp(從PATH 環境變量中查找文件並執行)
相關函數
    fork,execl,execle,execv,execve,execvp
表頭文件
    #include<unistd.h>
定義函數
    int execlp(const char * file,const char * arg,……);
函數說明
    execlp()會從PATH 環境變量所指的目錄中查找符合參數file的文件名,找到後便執行該文件,然後將第二個以後的參數當做該文件的argv[0]、argv[1]……,最後一個參數必須用空指針(NULL)作結束。
返回值
    如果執行成功則函數不會返回,執行失敗則直接返回-1,失敗原因存於errno 中。
錯誤代碼
    參考execve()。
範例
    /* 執行ls -al /etc/passwd execlp()會依PATH 變量中的/bin找到/bin/ls */
#include<unistd.h>
main()
{
execlp(“ls”,”ls”,”-al”,”/etc/passwd”,(char *)0);
}

執行
    -rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
 

   
execv(執行文件)
相關函數
    fork,execl,execle,execlp,execve,execvp
表頭文件
    #include<unistd.h>
定義函數
    int execv (const char * path, char * const argv[ ]);
函數說明
    execv()用來執行參數path字符串所代表的文件路徑,與execl()不同的地方在於execve()只需兩個參數,第二個參數利用數組指針來傳遞給執行文件。
返回值
    如果執行成功則函數不會返回,執行失敗則直接返回-1,失敗原因存於errno 中。
錯誤代碼
    請參考execve()。
範例
    /* 執行/bin/ls -al /etc/passwd */
#include<unistd.h>
main()
{
char * argv[ ]={“ls”,”-al”,”/etc/passwd”,(char*) }};
execv(“/bin/ls”,argv);
}

執行
    -rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
 

   
execve(執行文件)
相關函數
    fork,execl,execle,execlp,execv,execvp
表頭文件
    #include<unistd.h>
定義函數
    int execve(const char * filename,char * const argv[ ],char * const envp[ ]);
函數說明
    execve()用來執行參數filename字符串所代表的文件路徑,第二個參數系利用數組指針來傳遞給執行文件,
    argv要傳遞給程序的完整參數列表,包括argv[0],它一般是執行程序的名字;最後一個參數則爲傳遞給執行文件的新環境變量數組。
返回值
    如果執行成功則函數不會返回,執行失敗則直接返回-1,失敗原因存於errno 中。
錯誤代碼
    EACCES
1. 欲執行的文件不具有用戶可執行的權限。
2. 欲執行的文件所屬的文件系統是以noexec 方式掛上。
3.欲執行的文件或script翻譯器非一般文件。
EPERM
1.進程處於被追蹤模式,執行者並不具有root權限,欲執行的文件具有SUID 或SGID 位。
2.欲執行的文件所屬的文件系統是以nosuid方式掛上,欲執行的文件具有SUID 或SGID 位元,但執行者並不具有root權限
/****************************************************************************
**
**        execve.c--Illustrate the usage of execve
**
*****************************************************************************/


#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>

int main( void )
{
        char* args[] = { "/bin/ls", NULL };

        if ( -1 == (execve("/bin/ls", args, NULL)) )
        {
                perror( "execve" );
                exit( EXIT_FAILURE);
        }
        
        puts( "shouldn't get here" );
        exit( EXIT_SUCCESS );
}
[root@localhost src]# gcc execve.c
[root@localhost src]# ./a.out
a.out  child_fork.c  execve.c  fork.c  getpid.c
 
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章