C語言execv()函數:執行文件函數
頭文件:
#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
C語言execve()函數:執行文件函數
頭文件:
#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
C語言execvp()函數:執行文件函數
頭文件:
#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
|
新聞熱點
疑難解答
圖片精選