跳至主要内容

linux代码获取某个进程的cpu、内存

struct CPUSnapShot
{
    CPUSnapShot()
    {
        char buff[256] = {0};                                                                                                                
        FILE * fd = fopen("/proc/stat", "r"); 
        fgets(buff, sizeof(buff), fd);
        
        fclose(fd);
        
        sscanf(buff, "%s %u %u %u %u %u %u %u %u %u", name, 
            &user, &nice, &system, &idle, 
            &iowait, &irq, &softirq, &stealstolen, 
            &guest);
            
    }

    unsigned int Total()
    {
        return user +
            nice +
            system +
            idle +
            iowait +
            irq +
            softirq +
            stealstolen +
            guest;
    }
    
    char name[256];
    unsigned int user;
    unsigned int nice;
    unsigned int system;
    unsigned int idle;
    unsigned int iowait;
    unsigned int irq;
    unsigned int softirq;
    unsigned int stealstolen;
    unsigned int guest;
};

struct ProcCPUSnapShot
{
    ProcCPUSnapShot()
    {
        char strLinkFile[1024];
  SPRINTF_SAFE(strLinkFile, "/proc/%d/stat", getpid());

        char buff[256] = {0};                                                                                                                
        FILE * fd = fopen(strLinkFile, "r"); 
        fgets(buff, sizeof(buff), fd);

        fclose(fd);

        char * tokenPtr = strtok(buff, " ");
        int i = 0;
        while (tokenPtr != NULL && i < 12)
        {
            tokenPtr = strtok(NULL, " ");
            i++;
        }
        
        SAFE_TEST_RET(tokenPtr, NULL);

        tokenPtr = strtok(NULL, " ");
        SAFE_TEST_RET(tokenPtr, NULL);
        utime = atoi(tokenPtr);
        
        tokenPtr = strtok(NULL, " ");
        SAFE_TEST_RET(tokenPtr, NULL);
        stime = atoi(tokenPtr);
       
        tokenPtr = strtok(NULL, " ");
        SAFE_TEST_RET(tokenPtr, NULL);
        cutime = atoi(tokenPtr);
        
        tokenPtr = strtok(NULL, " ");
        SAFE_TEST_RET(tokenPtr, NULL);
        cstime = atoi(tokenPtr);
        
    }
    
    unsigned int Total()
    {
        return utime + 
            stime + 
            cutime + 
            cstime;
    }
    
    unsigned int utime;
    unsigned int stime;
    unsigned int cutime;
    unsigned int cstime;
};

int GetCPUUseage(uint32_t & totalUse, uint32_t & curProcUse)
{
    static CPUSnapShot last;
    static ProcCPUSnapShot lastProc;

    CPUSnapShot cur;
    ProcCPUSnapShot curProc;

    totalUse = cur.Total() == last.Total() ? 0 : ((cur.Total() - last.Total()) - (cur.idle - last.idle)) * 10000 / (cur.Total() - last.Total());
    curProcUse = cur.Total() == last.Total() ? 0 : (curProc.Total() - lastProc.Total()) * 10000 / (cur.Total() - last.Total());

    last = cur;
    lastProc = curProc;
    
    return 0;
}

int GetLoadAvg(uint32_t & loadavg)
{
    char buff[256] = {0};                                                                                                                
    FILE * fd = fopen("/proc/loadavg", "r"); 
    fgets(buff, sizeof(buff), fd);
    
    fclose(fd);

    float floadavg = 0.f;
    sscanf(buff, "%f", &floadavg);

    loadavg = uint32_t(floadavg * 100);
    
    return 0;
}

int GetMemUseage(uint32_t & res, uint32_t & virt)
{
    char strLinkFile[1024];
 SPRINTF_SAFE(strLinkFile, "/proc/%d/status", getpid());

    char buff[1024] = {0};                                                                                                                
    FILE * fd = fopen(strLinkFile, "r"); 
    fread(buff, sizeof(buff), 1, fd);
    
    fclose(fd);

    char tmp1[256] = {0};  
    char tmp2[256] = {0};  
    
    char * p = NULL;
    p = strstr(buff, "VmSize");
    SAFE_TEST_RET_VAL(p, NULL, false);
    sscanf(p, "%s %u %s", tmp1, &virt, tmp2);

    p = strstr(buff, "VmRSS");
    SAFE_TEST_RET_VAL(p, NULL, false);
    sscanf(p, "%s %u %s", tmp1, &res, tmp2);

    res /= 1024;
    virt /= 1024;
    
    return 0;
}


评论

此博客中的热门博文

ncurses与readline结合

  #define _XOPEN_SOURCE 700       /* for wcswidth and 700 is for mbsnrtowcs */ #include<wchar.h> #include<ncurses.h>       /* ncurses.h includes stdio.h */ #include<stdlib.h> #include<string.h> #include<readline/readline.h> #include<locale.h>     int mygetstr( char *str, int y, int x){    WINDOW *win;    int size, col;    int ok = 0;    int width;    wchar_t wstr[80];    char *p;        getmaxyx(stdscr, size, col);        void getaline( char *s){      str = s;      rl_callback_handler_remove();      ok = 1;    }        rl_callback_handler_install( "" , getaline);    win = newwin(1, col-x, y, x);    while (1){      rl_callback_read_char(); ...

简单的整数最小乘积的解法

给定 n 个整数,每次可以从剩下的整数中取走两个整数并计算这两个整数的积。 若该操作进行 m 次,求每次计算的积之和的最小值。 Input / 输入格式 有多组测试数据。第一行输入一个整数 T(约 30)代表测试数据组数,对于每组数据: 第一行输入两个整数 n 和 m(1≤n≤10​5​​, 0≤m≤​2​​n​​),它们的含义如题中所述。 第二行输入 n 个整数 a​1​​,a​2​​,⋯,a​n​​(0≤a​i​​≤10​4​​)表示给定的整数。 Output / 输出格式 每组数据输出一行一个整数,表示积之和的最小值。 Sample Input / 样例输入 3 4 2 1 3 2 4 3 1 2 3 1 4 0 1 3 2 4 Sample Output / 样例输出 10 2 0   Hint / 样例说明 对于第一组样例数据,答案是 1×4+3×2=10。 对于第二组样例数据,答案是 2×1=2。 package main import (         "bufio"         "fmt"         "os"         "sort"         "strconv"         "strings" ) var ...

利用yellowdns解决dns污染问题

 很多网站的dns直接被污染成了127.0.0.1,这样一般就无法访问了,很多翻墙软件也认为是局域网,所以访问不了 这时候,使用yellowdns,将dns转发到远程。然后listen本地的53端口。再将dns服务器都改成本地 vi /etc/resolv.conf windows和路由器,也可以都更改