溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Linux系統(tǒng)下利用C程序輸出某進程的內(nèi)存占用信息

發(fā)布時間:2020-10-04 11:27:50 來源:腳本之家 閱讀:254 作者:daisy 欄目:服務(wù)器

前言

大家應(yīng)該都遇到過一種情況,在實際工作中有時需要程序打印出某個進程的內(nèi)存占用情況以作參考, 下面介紹一種通過Linux下的偽文件系統(tǒng) /proc 計算某進程內(nèi)存占用的程序?qū)崿F(xiàn)方法.下面話不多說了,來一起看看詳細(xì)的介紹吧。

實現(xiàn)分析

首先, 為什么會有所謂的 偽文件 呢. Linux系統(tǒng)的文件類型大致可分為三類: 普通文件, 目錄文件和偽文件. 偽文件不是用來存儲數(shù)據(jù)的, 因此這些文件不占用磁盤空間, 只是存在于內(nèi)存中. /proc 讓你可以與內(nèi)核內(nèi)部數(shù)據(jù)進行交互, 獲取有關(guān)進程的有用信息.

下面主要介紹一下 /proc 下面的四個文件: /proc/stat , /proc/meminfo , /proc/<pid>/stat , /proc/<pid>/status .

/proc/stat 存放系統(tǒng)的cpu時間, 該文件包含了所有cpu活動的信息.

cpu 72389 2891 16811 1148664 31374 0 67 0 0 0
cpu0 17608 452 3786 288899 6210 0 30 0 0 0
cpu1 18724 926 4598 285844 8911 0 15 0 0 0
cpu2 16803 658 3726 288710 7220 0 7 0 0 0
cpu3 19254 855 4700 285209 9032 0 13 0 0 0
...
...
...

/proc/meminfo 存放系統(tǒng)的內(nèi)存信息, 通過文件中各個變量的名字便可知其代表的信息.

MemTotal: 4046236 kB
MemFree:  1054440 kB
MemAvailable: 2460060 kB
Buffers:  359688 kB
Cached:  1158056 kB
SwapCached:  0 kB
Active:  2020096 kB
Inactive:  677948 kB
Active(anon): 1181376 kB

...
...
...

/proc/<pid>/stat 存放某個進程的cpu信息

2476 (firefox) S 1773 1910 1910 0 -1 4210688 3413511 1712 757 1 45466 4629 2 7 20 0 57 0 20381 1774743552 150565 18446744073709551615 94844693012480 94844693126372 140732961864784 140732961858304 139747170914269 0 0 4096 33572079 0 0 0 17 2 0 0 1178 0 0 94844695226592 94844695228536 94844713955328 140732961867643 140732961867668 140732961867668 140732961869791 0

/proc/<pid>/status 存放某個進程的cpu信息以及一些綜合信息

Name: firefox
State: S (sleeping)
Tgid: 2476
Ngid: 0
Pid: 2476
PPid: 1773
TracerPid: 0
Uid: 1000 1000 1000 1000
Gid: 1000 1000 1000 1000
FDSize: 256
Groups: 4 24 27 30 46 108 124 1000 
NStgid: 2476
NSpid: 2476
NSpgid: 1910
NSsid: 1910
VmPeak: 1722812 kB
VmSize: 1690920 kB
VmLck:   0 kB
VmPin:   0 kB
VmHWM: 684048 kB
VmRSS: 600324 kB
VmData: 993040 kB
VmStk:  192 kB
...
...
...

以上數(shù)據(jù)都可以通過文件讀取的方式來獲取. 根據(jù)自己實驗的需要可以計算相應(yīng)的數(shù)據(jù), 比如 pmem = VmRSS/MemTotal*100 等等.

示例代碼

下面只是貼出一個簡單的獲取某進程當(dāng)前時刻所占用的實際內(nèi)存的c代碼實現(xiàn)例子.

//get_mem.h
#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h> 
#include <assert.h>
#define VMRSS_LINE 21//VMRSS所在行, 注:根據(jù)不同的系統(tǒng),位置可能有所區(qū)別.
#define pid_t int
int get_phy_mem(const pid_t p)
{
 char file[64] = {0};//文件名
 FILE *fd;   //定義文件指針fd
 char line_buff[256] = {0}; //讀取行的緩沖區(qū)
 sprintf(file,"/proc/%d/status",p);
 fprintf (stderr, "current pid:%d\n", p);
 fd = fopen (file, "r"); //以R讀的方式打開文件再賦給指針fd
 //獲取vmrss:實際物理內(nèi)存占用
 int i;
 char name[32];//存放項目名稱
 int vmrss;//存放內(nèi)存
 //讀取VmRSS這一行的數(shù)據(jù)
 for (i=0;i<VMRSS_LINE-1;i++)
 {
  char* ret = fgets (line_buff, sizeof(line_buff), fd);
 }
 char* ret1 = fgets (line_buff, sizeof(line_buff), fd);
 sscanf (line_buff, "%s %d", name,&vmrss);
 fprintf (stderr, "====%s:%d====\n", name,vmrss);
 fclose(fd);  //關(guān)閉文件fd
 return vmrss;
}
int get_rmem(pid_t p)
{
 return get_phy_mem(p);
}
int get_total_mem()
{
 const char* file = "/proc/meminfo";//文件名
 FILE *fd;   //定義文件指針fd
 char line_buff[256] = {0}; //讀取行的緩沖區(qū)
 fd = fopen (file, "r"); //以R讀的方式打開文件再賦給指針fd
 //獲取memtotal:總內(nèi)存占用大小
 int i;
 char name[32];//存放項目名稱
 int memtotal;//存放內(nèi)存峰值大小
 char*ret = fgets (line_buff, sizeof(line_buff), fd);//讀取memtotal這一行的數(shù)據(jù),memtotal在第1行
 sscanf (line_buff, "%s %d", name,&memtotal);
 fprintf (stderr, "====%s:%d====\n", name,memtotal);
 fclose(fd);  //關(guān)閉文件fd
 return memtotal;
}

測試文件:

#include "get_mem.h"
int main()
{
int list[1024];
for(int i = 0; i < 1024; i++)
 list[i] = i;
int mem = get_rmem(getpid());

}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI