linux下execl函式的使用和比較

wzm10455發表於2013-01-16



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字串所代表的檔案路徑,第二個引數系利用陣列指標來傳遞給執行檔案,最後一個引數則為傳遞給執行檔案的新環境變數陣列。
返回值
如果執行成功則函式不會返回,執行失敗則直接返回-1,失敗原因存於errno 中。
錯誤程式碼
EACCES
1. 欲執行的檔案不具有使用者可執行的許可權。
2. 欲執行的檔案所屬的檔案系統是以noexec 方式掛上。
3.欲執行的檔案或script翻譯器非一般檔案。
EPERM
1.程式處於被追蹤模式,執行者並不具有root許可權,欲執行的檔案具有SUID 或SGID 位。
2.欲執行的檔案所屬的檔案系統是以nosuid方式掛上,欲執行的檔案具有SUID 或SGID 位元,但執行者並不具有root許可權。
E2BIG 引數陣列過大
ENOEXEC 無法判斷欲執行檔案的執行檔案格式,有可能是格式錯誤或無法在此平臺執行。
EFAULT 引數filename所指的字串地址超出可存取空間範圍。
ENAMETOOLONG 引數filename所指的字串太長。
ENOENT 引數filename字串所指定的檔案不存在。
ENOMEM 核心記憶體不足
ENOTDIR 引數filename字串所包含的目錄路徑並非有效目錄
EACCES 引數filename字串所包含的目錄路徑無法存取,許可權不足
ELOOP 過多的符號連線
ETXTBUSY 欲執行的檔案已被其他程式開啟而且正把資料寫入該檔案中
EIO I/O 存取錯誤
ENFILE 已達到系統所允許的開啟檔案總數。
EMFILE 已達到系統所允許單一程式所能開啟的檔案總數。
EINVAL 欲執行檔案的ELF執行格式不只一個PT_INTERP節區
EISDIR ELF翻譯器為一目錄
ELIBBAD ELF翻譯器有問題。
範例
#include<unistd.h>
main()
{
char * argv[ ]={“ls”,”-al”,”/etc/passwd”,(char *)0};
char * envp[ ]={“PATH=/bin”,0}
execve(“/bin/ls”,argv,envp);
}
執行
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
 



execvp(執行檔案)
相關函式
fork,execl,execle,execlp,execv,execve
表標頭檔案
#include<unistd.h>
定義函式
int execvp(const char *file ,char * const argv []);
函式說明
execvp()會從PATH 環境變數所指的目錄中查詢符合引數file 的檔名,找到後便執行該檔案,然後將第二個引數argv傳給該欲執行的檔案。
返回值
如果執行成功則函式不會返回,執行失敗則直接返回-1,失敗原因存於errno中。
錯誤程式碼
請參考execve()。
範例
/*請與execlp()範例對照*/
#include<unistd.h>
main()
{
char * argv[ ] ={ “ls”,”-al”,”/etc/passwd”,0};
execvp(“ls”,argv);
}
執行
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd



相關文章