Linux下使⽤popen()执⾏shell命令
简单说⼀下popen()函数,可以⽤linux命令来简化⼀些操作,例如grep进程名,判断进程是否存在。
函数定义
#include <stdio.h>
FILE * popen(const char *command , const char *type );
int pclose(FILE *stream);
linux执行shell命令函数说明
popen()函数通过创建⼀个管道,调⽤fork()产⽣⼀个⼦进程,执⾏⼀个shell以运⾏命令来开启⼀个进程。这个管道必须由pclose()函数关闭,⽽不是fclose()函数。pclose()函数关闭标准I/O流,等待命令执⾏结束,然后返回shell的终⽌状态。如果shell不能被执⾏,则pclose()返回的终⽌状态与shell已执⾏exit⼀样。
type参数只能是读或者写中的⼀种,得到的返回值(标准I/O流)也具有和type相应的只读或只写类型。如果type是"r"则⽂件指针连接到command的标准输出;如果type是"w"则⽂件指针连接到command的标准输⼊。
command参数是⼀个指向以NULL结束的shell命令字符串的指针。这⾏命令将被传到bin/sh并使⽤-c标志,shell将执⾏这个命令。
popen()的返回值是个标准I/O流,必须由pclose来终⽌。前⾯提到这个流是单向的(只能⽤于读或写)。向这个流写内容相当于写⼊该命令的标准输⼊,命令的标准输出和调⽤popen()的进程相同;与之相反的,从流中读数据相当于读取命令的标准输出,命令的标准输⼊和调⽤popen()的进程相同。
返回值
如果调⽤fork()或pipe()失败,或者不能分配内存将返回NULL,否则返回标准I/O流。popen()没有为内存分配失败设置errno值。如果调⽤fork()或pipe()时出现错误,errno被设为相应的错误类型。如果type参数不合法,errno将返回EINVAL。
附上⼀个例⼦:
//execute shell command
//执⾏⼀个shell命令,输出结果逐⾏存储在resvec中,并返回⾏数
int32_t myexec(const char *cmd, vector<string> &resvec) {
resvec.clear();
FILE *pp = popen(cmd, "r"); //建⽴管道
if (!pp) {
return -1;
}
char tmp[1024]; //设置⼀个合适的长度,以存储每⼀⾏输出
while (fgets(tmp, sizeof(tmp), pp) != NULL) {
if (tmp[strlen(tmp) - 1] == '\n') {
tmp[strlen(tmp) - 1] = '\0'; //去除换⾏符
}
resvec.push_back(tmp);
}
pclose(pp); //关闭管道
return resvec.size();
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论