linux如何使用管道命令執(zhí)行ps獲取cpu與內(nèi)存占用率-創(chuàng)新互聯(lián)

本篇內(nèi)容介紹了“l(fā)inux如何使用管道命令執(zhí)行ps獲取cpu與內(nèi)存占用率”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都做網(wǎng)站、網(wǎng)站設(shè)計、七臺河網(wǎng)絡(luò)推廣、小程序開發(fā)、七臺河網(wǎng)絡(luò)營銷、七臺河企業(yè)策劃、七臺河品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們大的嘉獎;成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供七臺河建站搭建服務(wù),24小時服務(wù)熱線:18980820575,官方網(wǎng)址:muchs.cn

代碼如下:


#include <stdio.h>
#include <unistd.h>
int main()
{
    char caStdOutLine[1024]; // ps 命令的標(biāo)準(zhǔn)輸出中的一行信息
    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 // 非循環(huán),只是為了方便控制分支層次,便于控制分支流向
    {
        // 通過創(chuàng)建一個管道,調(diào)用 fork 產(chǎn)生一個子進程,
        // 執(zhí)行一個 shell 以運行命令來開啟一個進程。
        // 這個進程必須由 pclose() 函數(shù)關(guān)閉。
        FILE* fp = popen( caPSCmd, // 一個指向以 NULL 結(jié)束的 shell 命令字符串的指針,
                                   // 這行命令將被傳到 bin/sh 并使用 -c 標(biāo)志,
                                   // 那么 shell 將執(zhí)行這個命令從這個字符串中讀取。
                          "r" );   // 文件指針連接到 shell 命令的標(biāo)準(zhǔn)輸出

        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;
        }

        // 關(guān)閉標(biāo)準(zhǔn) I/O 流,等待命令執(zhí)行結(jié)束,然后返回 shell 的終止?fàn)顟B(tài)。
        // 如果 shell 不能被執(zhí)行,
        // 則 pclose() 返回的終止?fàn)顟B(tài)與 shell 已執(zhí)行 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


“l(fā)inux如何使用管道命令執(zhí)行ps獲取cpu與內(nèi)存占用率”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

本文標(biāo)題:linux如何使用管道命令執(zhí)行ps獲取cpu與內(nèi)存占用率-創(chuàng)新互聯(lián)
當(dāng)前鏈接:http://muchs.cn/article0/depooo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管企業(yè)建站、網(wǎng)站設(shè)計公司、關(guān)鍵詞優(yōu)化商城網(wǎng)站、外貿(mào)建站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)