手机
当前位置:查字典教程网 >脚本专栏 >linuxshell >linux使用管道命令执行ps获取cpu与内存占用率
linux使用管道命令执行ps获取cpu与内存占用率
摘要:复制代码代码如下:#include#includeintmain(){charcaStdOutLine[1024];//ps命令的标准输出中...

复制代码 代码如下:

#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 failedn" );

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与内存占用率】相关文章:

shell获取命令行参数示例分享

linux中压缩与备份命令大全

linux下安装oracle后使用命令行启动的方法 linux启动oracle

linux shell命令执行顺序的控制方法

Linux常用命令全集(超全面)

linux shell命令行选项与参数用法详解

详解Linux中vi命令大全

Linux Shell中判断进程是否存在的代码

Linux命令行里的“瑞士军刀”

Linux BASH多进程并行处理的方法实现

精品推荐
分类导航