在linux系统中,我们要想执行一个命令,可以使用system()或者exec()或者popen()函数来完成。有时候,我们要将取得命令的返回结果,并处理这些结果,这个时候,就需要用popen()了。
本文就是演示了popen()的用法。需要注意的是popen()需要和pclose()同时使用,就像打开文件和关闭文件同时使用一样。
程序的思路:在用malloc()申请一块内存之后,就显示一下这个进程的内存使用量,free()一块内存的时候,也显示一下内存的使用量。
/*
cc -g malloc2.c -o malloc2
*/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#define MAX 20
char *mallocMemory(int i)
{
char *p = malloc(1024 * 1024 * sizeof(char));
printf("%d\tchar *p = malloc(1024*1024*sizeof(char));\t addr is %p\n", i, p);
return p;
}
void getMemoryInfo(char *msg, int size, char *cmd)
{
FILE *fp = NULL;
fp = popen(cmd, "r");
if (fp == NULL)
{
return;
}
fread(msg, sizeof(char), size, fp);
pclose(fp);
}
int main(int argc, char **argv)
{
int i = 0;
char *cmd = "ps -aux | grep malloc2 | grep -v grep | grep -v tail && date";
int system_return = 0;
char msg[1000] = {0};
char *p_malloc[MAX] = {0};
getMemoryInfo(msg, sizeof(msg), cmd);
printf("%s", msg);
for (; i < MAX; i++)
{
p_malloc[i] = mallocMemory(i);
memset(msg, 0x00, sizeof(msg));
getMemoryInfo(msg, sizeof(msg), cmd);
printf("%s", msg);
sleep(10);
}
for (i = 0; i < MAX; i++)
{
printf("free(p_malloc[%d]);\n", i);
free(p_malloc[i]);
memset(msg, 0x00, sizeof(msg));
getMemoryInfo(msg, sizeof(msg), cmd);
printf("%s", msg);
sleep(10);
}
sleep(20);
memset(msg, 0x00, sizeof(msg));
getMemoryInfo(msg, sizeof(msg), cmd);
printf("%s", msg);
return 0;
}
程序的输出的结果略。通过输出的结果,可以看出,每一次malloc一块内存,程序的虚拟内存就会变大,每free一块内存,程序的虚拟内存就会变小。而物理内存的变化却滞后于虚拟内存的变化,它是代表了载入内存的可执行的代码的量。