文章目錄
簡單說一下popen()函數
函數定義
#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。
附上一個例子:
//execute shell command
//執行一個shell命令,輸出結果逐行儲存在resvec中,並返回行數int32_t myexec(const char *cmd, vector<string> &resvec) { resvec.clear(); FILE *pp = popen(cmd, "r"); //建立管道 if (!pp) { return -1; }
char tmp[1024]; //設定一個合適的長度,以儲存每一行輸出 while (fgets(tmp, sizeof(tmp), pp) != NULL) { if (tmp[strlen(tmp) - 1] == '\n') { tmp[strlen(tmp) - 1] = '\0'; //去除分行符號 } resvec.push_back(tmp); } pclose(pp); //關閉管道 return resvec.size();}