標籤:style blog http color 使用 os
轉載 http://www.cnblogs.com/caosiyang/archive/2012/06/25/2560976.html
簡單說一下popen()函數
函數定義
1 #include <stdio.h>2 3 FILE * popen(const char *command , const char *type );4 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。
附上一個例子:
1 //execute shell command 2 //執行一個shell命令,輸出結果逐行儲存在resvec中,並返回行數 3 int32_t myexec(const char *cmd, vector<string> &resvec) { 4 resvec.clear(); 5 FILE *pp = popen(cmd, "r"); //建立管道 6 if (!pp) { 7 return -1; 8 } 9 char tmp[1024]; //設定一個合適的長度,以儲存每一行輸出10 while (fgets(tmp, sizeof(tmp), pp) != NULL) {11 if (tmp[strlen(tmp) - 1] == ‘\n‘) {12 tmp[strlen(tmp) - 1] = ‘\0‘; //去除分行符號13 }14 resvec.push_back(tmp);15 }16 pclose(pp); //關閉管道17 return resvec.size();18 }