管道:把一个进程的输出连接到另一个进程的输入 单向
实现管道的方式之一:popen
FILE *popen(const char *command, const char *open_mode);
int pclose(FILE *to_be_close);
popen 允许一个程序将另一个程序作为新进程来启动,并可以给它传递数据或者从它读取数据。command 为另一个程序的启动方式,open_mode 为 “r” 或者 "w"。如果为 "r",表示被调用程序的输出可以被调用程序使用,通过 fread 读取,如果是 “w”,表示调用程序可以通过 fwrite 向被调用程序发送数据,而被调用程序可以从自己的标准输入中读取这些数据。
同样是单向的。如果想实现双向读写,则必须实现 2 个管道,各负责一个方向。
int main()
{
......
fp = popen("uname -a", "r");
if (NULL != fp) {
fread(buffer, 1, BUFSIZ, fp);
......
}
pclose(fp);
......
}
用 GDB 跟踪可以发现,popen 会启动一个 shell,用于解析 command 命令。这是其优点,但同时也是缺点。利用 shell,可以很方便的完成 command 中的参数扩展,但是 shell 也是一个独立的进程,因此,一次 popen 调用,将至少启动 2 个独立的进程,消耗了资源。
该方式类似于 system,同样会启动一个 shell,并且运行字符串形式的命令。但 system 默认将执行结果输出到标准输出,不支持读取,也不支持向命令输入信息。此外,调用 system 后,将阻塞直至命令执行完毕,因此,可以后台执行该命令,此时 system 将立即返回。