Linux C popen使用方式

進程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;
  }


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章