轉載自:https://blog.csdn.net/stone8761/article/details/77498439
popen() 可以執行 shell 命令,並讀取此命令的返回值
popen() 函數通過創建一個管道,調用 fork() 產生一個子進程,調用一個 shell 以運行命令來開啓一個進程。可以通過這個管道執行標準輸入輸出操作。這個管道必須由 pclose() 函數關閉,必須由 pclose() 函數關閉,必須由 pclose() 函數關閉,而不是 fclose() 函數(若使用 fclose() 則會產生殭屍進程)。pclose() 函數關閉標準 I/O 流,等待命令執行結束,然後返回 shell 的終止狀態。如果 shell 不能被執行,則 pclose() 返回的終止狀態與 shell 已執行 exit 一樣。
函數原型
FILE *popen(const char *command, const char *type);
int pclose(FILE *stream);
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。
例:
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
void print_result(FILE *fp)
{
char buf[100];
if(!fp) {
return;
}
printf("\n>>>\n");
while(memset(buf, 0, sizeof(buf)), fgets(buf, sizeof(buf) - 1, fp) != 0 ) {
printf("%s", buf);
}
printf("\n<<<\n");
}
int main(void)
{
FILE *fp = NULL;
while(1) {
fp = NULL;
fp = popen("ls", "r");
if(!fp) {
perror("popen");
exit(EXIT_FAILURE);
}
print_result(fp);
pclose(fp);
sleep(1);
}
}