popen,程序中执行shell命令

popen()可以执行shell命令,并读取此命令的返回值;  
popen()函数通过创建一个管道,调用fork()产生一个子进程,执行一个shell以运行命令来开启一个进程。可以通过这个管道执行标准输入输出操作。这个管道必须由pclose()函数关闭,必须由pclose()函数关闭,必须由pclose()函数关闭,而不是fclose()函数(若使用fclose则会产生僵尸进程)。pclose()函数关闭标准I/O流,等待命令执行结束,然后返回shell的终止状态。如果shell不能被执行,则pclose()返回的终止状态与shell已执行exit一样。

函数原型:
FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);

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。

根据上面这段话可知,popen的返回值只与是否fork或者分配空间成功有关。至于我们的shell命令是成功还是失败呢?取决于pclose的返回值,如果返回0,代表shell命令成功,否则失败。

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
 
void print_result(FILE *fp)
{
	char buf[100];
 
	if(!fp) return;
	
	while(memset(buf, 0, sizeof(buf)), fgets(buf, sizeof(buf) - 1, fp))
		printf("%s", buf);
}
 
int main(void)
{
	FILE *fp = NULL;
	int ret = 0;
	
	fp = popen("ls", "r");
	if(!fp) {
		perror("popen error!");
		exit(EXIT_FAILURE);
	}
	print_result(fp);
	if (ret = pclose(fp)){
		perror("shell error, ret = %d!", ret);
		return -1;
	}

	return 0;
}

原文链接:https://blog.csdn.net/stone8761/article/details/77498439

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值