一、system函数
头文件
#include <stdlib.h>
函数原型
int system(const char *command);
函数说明
system()会调用fork()产生子进程,由子进程来调用/bin/sh-c string来执行参数string字符串所代表的命令,此命令执行完后随即返回原调用的进程。在调用system()期间SIGCHLD 信号会被暂时搁置,SIGINT和SIGQUIT 信号则会被忽略。
返回值
如果system()在调用/bin/sh时失败则返回127,其他失败原因返回-1。若参数string为空指针(NULL),则返回非零值。如果 system()调用成功则最后会返回执行shell命令后的返回值,但是此返回值也有可能为system()调用/bin/sh失败所返回的127,因此最好能再检查errno 来确认执行成功。
例如
此处源码与相似exec族函数和fork
只需修改一行,将原来的 execl("./data",“data”,“NULL”,NULL); 换为 system("./data");
#include <unistd.h>
#include <stdio.h>
int main()
{
pid_t pid;
int data = 0;
while(1){
printf("please input a data\n");
scanf("%d",&data);
if(data == 1){
pid = fork();
if(pid > 0){
wait(NULL);
}
if(pid == 0){
// execl("./data","data","NULL",NULL);
system("./data");
printf("system return success\n");
}
}else{
printf("wait, do nothing\n");
}
}
return 0;
}
注:system函数调用可执行文件后会返回到子进程中继续执行下面的代码,execl函数不会返回
二、popen函数
popen函数在应用中比system函数好的一点在于,前者可以获取到运行的输出结果
头文件
#include <stdio.h>
函数原型
FILE *popen(const char *command, const char *type);
int pclose (FILE* stream)
参数说明:
command: 是一个指向以 NULL 结束的 shell 命令字符串的指针。这行命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令。
type: 只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型。
如果 type 是 “r” 则文件指针连接到 command 的标准输出;
如果 type 是 “w” 则文件指针连接到 command 的标准输入。
stream:将popen返回的文件指针关闭
返回值:成功,则返回一个读或者打开文件的指针失败,返回NULL
读取:需要使用fread()来读取popen产生的管道中的内容
size_t fread(void *ptr, size_t size, size_t nmemb, FILE *stream);
popen() 函数用于创建一个管道:其内部实现为调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一个进程这个进程必须由 pclose() 函数关闭。
#include <unistd.h>
#include <stdio.h>
int main()
{
char ret[1024] = {0};
FILE *fp = NULL;
fp = popen("ls","r"); //以读的方式打开ls
int nread = fread(ret,1,1024,fp);
printf("read ret %d byte, ret = %s\n",nread,ret);
fclose(fp);
return 0;
}
如果不用popen的话,ls命令的内容会显示到屏幕终端上面,如果用popen会将ls命令读到ret中,如果没有printf打印出来,就不会显示,