https://blog.csdn.net/libinbin_1014/article/details/51490568
代码参考
函数原型:
#include “stdio.h”
FILE popen( const char command, const char* mode )
参数说明:
command: 是一个指向以 NULL 结束的 shell 命令字符串的指针。这行命令将被传到 bin/sh 并使用 -c 标志,shell 将执行这个命令。
mode: 只能是读或者写中的一种,得到的返回值(标准 I/O 流)也具有和 type 相应的只读或只写类型。如果 type 是 “r” 则文件指针连接到 command 的标准输出;如果 type 是 “w” 则文件指针连接到 command 的标准输入。
返回值:
如果调用成功,则返回一个读或者打开文件的指针,如果失败,返回NULL,具体错误要根据errno判断
int pclose (FILE* stream)
参数说明:
stream:popen返回的文件指针
返回值:..............略
比system在应用中的好处:
可以获取运行的输出结果
之前
int main(){
system("ps");
return 0;
}
PID TTY TIME CMD
24197 pts/7 00:00:00 bash
25878 pts/7 00:00:00 a.out
25879 pts/7 00:00:00 sh
25880 pts/7 00:00:00 ps
结果只是打在屏幕上
而且execl执行成功 不会返回
问题?
想让把它的值保存到文件或者放到字符串里面,通过网络发出来,怎么实现?
了解了system之后,我们再来看一看popen函数,它又有什么好处呢,哎,它厉害了,它能做到system做不到的一件事:把执行返回的结果保存下来,到文件或者其他形式当中去,换句话说,system执行后结果是保存不了的,虽然它执行了你的命令,但结果你是看不到的,然而popen可以做到
原文为:本文参考引用CSDN博主「木下 似水」的原创文章
popen把返回结果送进了一个流(一个管道),而C库的fread可以从流中读出数据,这样我们就做到了把返回结果保存下来,我们来尝试一下:
int main(){
char ptr[1024]={0};
FILE *fd;
fd= popen("ps","r");
int n_fread=fread(ptr,1,1024,fd);
printf("n_fread byte =%d, ptr data=%s\n",n_fread,ptr);
return 0;
}
结果为:
CLC@Embed_Learn:~/proceed$ ./a.out
n_fread byte =141, ptr data= PID TTY TIME CMD
24197 pts/7 00:00:00 bash
26155 pts/7 00:00:00 a.out
26156 pts/7 00:00:00 sh
26157 pts/7 00:00:00 ps