|
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 指標(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 指標(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
|
|