Linux下使用函数popen和pclose
函数popen和pclose
常见的操作是创建一个连接到另一个进程的管道,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose。这两个函数实现的操作是:创建一个管道,fork一个子进程,关闭未使用的管道端,执行一个shell运行命令,然后等待命令终止。
NAME
popen, pclose - pipe stream to or from a process
SYNOPSIS
#include <stdio.h>
FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);
//popen 的返回值是个标准 I/O 流,必须由 pclose 来终止。
①功能:
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 将执行这个命令
与函数system相比,函数popen应用中的好处可以获取运行的输出结果。
#include <stdio.h>
int main()
{
char readbuf[1024] = {0};
FILE *fp;
fp = popen("ps -l","r");
int nfread = fread(readbuf,1,1024,fp);
printf("read %d byte:%s\n",nfread,readbuf);
pclose(fp);
return 0;
}
编译运行结果如下:
#include <stdio.h>
int main()
{
char readbuf[1024] = {0};
FILE *fp;
fp = popen("ps -l","r");
// int nfread = fread(readbuf,1,1024,fp);
// printf("read %d byte:%s\n",nfread,readbuf);
printf("over\n");
pclose(fp);
return 0;
}
若不进行读操作,编译运行结果如下: