引用度娘说的:
popen() 函数通过创建一个管道,调用 fork 产生一个子进程,执行一个 shell 以运行命令来开启一个进程。
这个进程必须由 pclose() 函数关闭,而不是 fclose() 函数。pclose() 函数关闭标准 I/O 流,等待命令执行结束,然后返回 shell 的终止状态。如果 shell 不能被执行,则 pclose() 返回的终止状态与 shell 已执行 exit 一样。
也就是,popen创建管道,执行shell命令将文件流中的某些数据读出
看看man手册
NAME
popen, pclose - pipe stream to or from a process
SYNOPSIS
#include//头文件
FILE *popen(const char *command, const char *type);//原型
参数说明:
command: 是一个指向以 NULL 结束的 shell 命令字符串的指针。命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令,比如sh -c ls
type: 只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型。如果 type 是 “r” 则文件指针连接到 command 的标准输出;如果 type 是 “w” 则文件指针连接到 command 的标准输入。
返回值:
如果调用 fork() 或 pipe() 失败,或者不能分配内存将返回NULL,否则返回一个读或者打开文件的指针。
接下来看看demo
#include#includeint main(int argc ,char **argv){ char ret[1024] = {0};
FILE *fp;
//FILE *popen(const char *command, const char *type);
fp = popen("ls -l","r");
//size_t fwrite(const void *ptr, size_t size, size_t nmemb,FILE *stream);
int nread = fread(ret,1,1024,fp);
printf("read ret %d byte, %s\n",nread,ret);
return 0;
}
这个demo很好的验证了通过管道输出的情况,通过调用popen去执行ls -l命令,把结果给fp,通过fread读取。所以,popen和system的表面区别在于system执行之后直接把结果显示了,而不能去进行读或者写
结果如下:
把read ret 1024 byte, total 140打印了出来,还显示了全部文件信息
ending!!!
你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
售后响应及时
7×24小时客服热线数据备份
更安全、更高效、更稳定价格公道精准
项目经理精准报价不弄虚作假合作无风险
重合同讲信誉,无效全额退款