博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux 下用管道执行 ps aux | grep 进程ID 来获取CPU与内存占用率
阅读量:6373 次
发布时间:2019-06-23

本文共 1560 字,大约阅读时间需要 5 分钟。

#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
 
转自:http://blog.sina.com.cn/s/blog_4c451e0e0101cmrq.html

转载地址:http://tvjqa.baihongyu.com/

你可能感兴趣的文章
17.移动架构手写数据库增删改查框架
查看>>
安装ansible-2.5.0
查看>>
内核模块遍历进程和任务队列保存到proc文件中
查看>>
爬取高德地图poi数据
查看>>
从多核硬件架构,看Java内存模型
查看>>
第5章—构建Spring Web应用程序—关于spring中的validate注解后台校验的解析
查看>>
fastJson顺序遍历JSON字段
查看>>
ES6 + Angular 1.x
查看>>
XtraBackup不停机不锁表搭建MySQL主从同步实践
查看>>
Linux Dailly
查看>>
Docker学习之路(一)
查看>>
Java工程师知识图谱
查看>>
[Spring实战系列](2)Maven创建Spring-HelloWorld项目
查看>>
CentOS安装运行NodeJS框架Express
查看>>
白话版 动态规划法
查看>>
(十六) 整合spring cloud云架构 -使用spring cloud Bus刷新配置
查看>>
全面总结国内BATH等大厂开源的安卓有关的库(持续更新中...)
查看>>
NutUI 2.1.0 发布,移动端轻量级 Vue 组件库
查看>>
缓存系列文章--热点key问题
查看>>
CSS动画小结
查看>>