您好,登錄后才能下訂單哦!
本篇內容介紹了“linux如何使用管道命令執行ps獲取cpu與內存占用率”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
代碼如下:
#include <stdio.h>
#include <unistd.h>
int main()
{
char caStdOutLine[1024]; // ps 命令的標準輸出中的一行信息
char* pcTmp = NULL; // 指向以空格拆分后的字符串
char caSelfPID[10]; // 自身進程的PID字符串
char caPSCmd[24]; // "ps aux | grep PID"命令字符串
memset( caSelfPID, 0, sizeof( caSelfPID ) );
sprintf( caSelfPID,
"%d",
getpid() );
memset( caPSCmd, 0, sizeof( caPSCmd ) );
sprintf( caPSCmd,
"ps aux | grep %d",
getpid() );
do // 非循環,只是為了方便控制分支層次,便于控制分支流向
{
// 通過創建一個管道,調用 fork 產生一個子進程,
// 執行一個 shell 以運行命令來開啟一個進程。
// 這個進程必須由 pclose() 函數關閉。
FILE* fp = popen( caPSCmd, // 一個指向以 NULL 結束的 shell 命令字符串的指針,
// 這行命令將被傳到 bin/sh 并使用 -c 標志,
// 那么 shell 將執行這個命令從這個字符串中讀取。
"r" ); // 文件指針連接到 shell 命令的標準輸出
if ( NULL == fp )
{
printf( "call popen is failed\n" );
break;
}
memset( caStdOutLine, 0, sizeof( caStdOutLine ) );
while ( NULL != fgets( caStdOutLine,
sizeof( caStdOutLine ),
fp ) )
{
// 再以空格分隔符拆分字符串
pcTmp = strtok( caStdOutLine, " " );
// 用戶名跳過,直接匹配 PID ,不匹配跳過
pcTmp = strtok( NULL, " " );
if ( 0 != strncasecmp( caSelfPID,
pcTmp,
strlen( caSelfPID ) ) )
{
continue;
}
// 讀出進程自身 CPU 占用率
pcTmp = strtok( NULL, " " );
printf( "CPU = %s %%\n", pcTmp );
// 讀出進程自身 MEM 占用率
pcTmp = strtok( NULL, " " );
printf( "MEM = %s %%\n", pcTmp );
break;
}
// 關閉標準 I/O 流,等待命令執行結束,然后返回 shell 的終止狀態。
// 如果 shell 不能被執行,
// 則 pclose() 返回的終止狀態與 shell 已執行 exit 一樣。
pclose( fp );
}while ( 0 );
}
代碼如下:
$ gcc main.c -o test
$ ./test
CPU = 1.0 %
MEM = 0.0 %
$ ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
nsc 24505 1.0 0.0 2004 232 pts/0 S+ 09:46 0:00 ./test
“linux如何使用管道命令執行ps獲取cpu與內存占用率”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。