您的位置:首页 > 运维架构 > Linux

Linux popen用法

2012-10-31 08:49 344 查看


popen

Linux C

  进程I/O函数,与pclose函数一起使用。

表头文件

  #include <stdio.h>

函数定义

  FILE * popen ( const char * command , const char * type );

  int pclose ( FILE * stream );

函数说明

  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 将执行这个命令。

  popen 的返回值是个标准 I/O 流,必须由 pclose 来终止。前面提到这个流是单向的。所以向这个流写内容相当于写入该命令的标准输入;命令的标准输出和调用 popen 的进程相同。与之相反的,从流中读数据相当于读取命令的标准输出;命令的标准输入和调用 popen 的进程相同。

返回值

  如果调用 fork() 或 pipe() 失败,或者不能分配内存将返回NULL,否则返回标准 I/O 流。

返回错误

  popen 没有为内存分配失败设置 errno 值。

  如果调用 fork() 或 pipe() 时出现错误,errno 被设为相应的错误类型。

  如果 type 参数不合法,errno将返回EINVAL。

使用举例

  if((fp=popen("/usr/bin/uptime","r"))==NULL);

  {

  sprintf(buf,"error: %s\n", strerror(errno));

  ....//异常处理

  }

  else

  {

  ....

  pclose(fp);

  }

  真实示例 

  #define _LINE_LENGTH 300

  int get_path_total(const char *path, long long* total) {

  int err=-1;

  FILE *file;

  char line[_LINE_LENGTH];

  char *p;

  char tmp[100];

  char *token;

  sprintf(tmp, "df %s", path);

  file = popen(tmp, "r");

  if (file != NULL) {

  if (fgets(line, _LINE_LENGTH, file) != NULL) {

  if (fgets(line, _LINE_LENGTH, file) != NULL) {

  token = strtok(line, " ");

  if (token != NULL) {

  // printf("token=%s\n", token);

  }

  token = strtok(NULL, " ");

  if (token != NULL) {

  // printf("token=%s\n", token);

  *total=atoll(token)/1024;//k/1024

  err=0;

  }

  }

  }

  pclose(file);

  }

  return err;

  }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: