2 回答

TA貢獻1884條經(jīng)驗 獲得超4個贊
標(biāo)準(zhǔn)的c函數(shù)庫是所有的編譯都要具有的函數(shù)庫,(實際上還是略有不同),但是這些基本上實現(xiàn)方法略有不同,但是結(jié)果和標(biāo)準(zhǔn)是一樣的。但是linux的系統(tǒng)調(diào)用,調(diào)用是linux的系統(tǒng)庫,比如說unistd.h下的fork這個是Linux下特有,你在vs上,就沒有這個庫,也沒有這個函數(shù)。同樣在vs上寫c,你可以引入頭文件比如windows.h,顯然這個庫是Linux不具有的。簡單說系統(tǒng)調(diào)用庫根據(jù)具體的操作系統(tǒng)環(huán)境不同而不同,而c標(biāo)準(zhǔn)庫,是所有支持c語言編譯器都有的。

TA貢獻1906條經(jīng)驗 獲得超3個贊
linux c system函數(shù)介紹:
system(執(zhí)行shell 命令)
相關(guān)函數(shù)
fork,execve,waitpid,popen
表頭文件
#i nclude
定義函數(shù)
int system(const char * string);
函數(shù)說明
system()會調(diào)用fork()產(chǎn)生子進程,由子進程來調(diào)用/bin/sh-c string來執(zhí)行參數(shù)string字符串所代表的命令,此命>令執(zhí)行完后隨即返回原調(diào)用的進程。在調(diào)用system()期間SIGCHLD 信號會被暫時擱置,SIGINT和SIGQUIT 信號則會被忽略。
返回值
=-1:出現(xiàn)錯誤
=0:調(diào)用成功但是沒有出現(xiàn)子進程
>0:成功退出的子進程的id
如果system()在調(diào)用/bin/sh時失敗則返回127,其他失敗原因返回-1。若參數(shù)string為空指針(NULL),則返回非零值>。如果system()調(diào)用成功則最后會返回執(zhí)行shell命令后的返回值,但是此返回值也有可能為 system()調(diào)用/bin/sh失敗所返回的127,因此最好能再檢查errno 來確認(rèn)執(zhí)行成功。
附加說明
在編寫具有SUID/SGID權(quán)限的程序時請勿使用system(),system()會繼承環(huán)境變量,通過環(huán)境變量可能會造成系統(tǒng)安全的問題。
范例
#i nclude
main()
{
system("ls -al /etc/passwd /etc/shadow");
}
執(zhí)行結(jié)果:
-rw-r--r-- 1 root root 705 Sep 3 13 :52 /etc/passwd
-r--------- 1 root root 572 Sep 2 15 :34 /etc/shado
例2:
char tmp[];
sprintf(tmp,"/bin/mount -t vfat %s /mnt/usb",dev);
system(tmp);
其中dev是/dev/sda1。
system函數(shù)的源碼
#include <syspes.h>
#include <sys/wait.h>
#include <errno.h>
#include <unistd.h>
int system(const char * cmdstring)
{
pid_t pid;
int status;
if(cmdstring == NULL){
return (1);
}
if((pid = fork())<0){
status = -1;
}
else if(pid = 0){
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
-exit(127); //子進程正常執(zhí)行則不會執(zhí)行此語句
}
else
{
while(waitpid(pid, &status, 0) < 0){
if(errno != EINTER)
{
status = -1;
break;
}
}
}
return status;
}
那么如何獲得system的返回值呢??
char buf[10];
char * ps="ps -ef|grep -c root";
FILE *ptr;
int i;
if((ptr = popen(ps, "r")) != NULL)
{
fgets(buf, 10 , ptr);
i = atoi(buf);
pclose(ptr);
}
可以man下waitpid查看下如何檢查status的值
int ret = system("ls -al /etc/passwd /etc/shadow");
if(WIFSIGNALED(ret))
添加回答
舉報