您好,登录后才能下订单哦!
本篇内容介绍了“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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。