linux使用popen讀取shell命令執行結果
popen函式詳解
描述
popen() 函式 用 建立管道 的 方式 啟動 一個 程序, 並呼叫 shell. 因為 管道 是被定義成 單向的, 所以 type 引數 只能 定義成 只讀 或者 只寫, 不能是 兩者同時, 結果流 也相應的 是 只讀 或者 只寫.
command 引數 是 一個 字串指標, 指向的 是 一個 以 null 結束符 結尾的字串, 這個 字串 包含 一個 shell 命令. 這個命令 被送到 /bin/sh 以 -c 引數 執行, 即由 shell 來執行. type 引數 也是 一個 指向 以 null 結束符 結尾的 字串的指標, 這個字串 必須是 'r' 或者 'w’ 來指明 是 讀還是寫.
popen() 函式 的 返回值 是 一個 普通的 標準I/O流, 它只能用 pclose() 函式 來關閉, 而不是 fclose(). 函式. 向 這個流 的 寫入 被轉化為 對 command 命令的 標準輸入; 而 command 命令的 標準輸出 則是和 呼叫 popen(), 函式 的 程序 相同,除非 這個 被command命令 自己 改變. 相反的, 讀取 一個 “被popen了的” 流, 就相當於 讀取 command 命令的 標準輸出, 而 command 的 標準輸入 則是和 呼叫 popen, 函式的 程序 相同.
注意, popen 函式的 輸出流 預設是 被全緩衝的.
pclose 函式 等待 相關的程序 結束 並返回 一個 command 命令的 退出狀態, 就像 wait4 函式 一樣
示例:
#include <stdio.h>
int main(int argc, char *argv[])
{
char buf[1024];
FILE *pp;
//r表示返回的指標是可讀的。
if( (pp = popen("ps", "r")) == NULL )
{
printf("popen() error!\n");
exit(1);
}
while(fgets(buf, sizeof buf, pp))
{
printf("%s", buf);
}
pclose(pp);
return 0;
}