[英]How to extract information from the content of /proc files on Linux using C?
我一直在为此工作 5 天,每天超过 7 小时。 我不是最好的编码员,所以我需要一些帮助。 我需要知道如何在 Linux 上使用 C 程序从 /proc 获取信息。 信息必须打印出来,并包括以下内容:
听起来你不知道从哪里开始。 让我尝试解释/proc
的信息:
如果我们cat /proc/29519/stat
,我们会得到以下信息:
29519 (vim) S 5997 29519 5997 34835 29519 24576 1275 0 47 0 5 0 0 0 20 0 2 0 49083340 188043264 3718 18446744073709551615 4194304 6665820 140737488349264 140737488347024 140737280970147 0 0 12288 1837256447 18446744073709551615 0 0 17 3 0 0 21 0 0 8764120 8861948 8925184 140737488349925 140737488349929 140737488349929 140737488351211 0
所有这些数字代表什么? 答案在man proc 中,在名为/proc/[pid]/stat
。 由此我们看到前四件事是:
pid %d
(1) 进程标识。
通讯 %s
(2) 可执行文件的文件名,在括号中。 无论可执行文件是否被换出,这都是可见的。
状态 %c
(3) 字符串“RSDZTW”中的一个字符,其中 R 正在运行,S 在可中断等待中休眠,D 在磁盘不可中断休眠中等待,Z 是僵尸,T 被跟踪或停止(在信号上),W 是分页。
ppid %d
(4) 父母的PID。
有了这些知识,我们可以用fscanf(f, "%d %s %c %d", ...)
解析它:
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
void main(int argc, char **argv) {
int pid;
sscanf(argv[1], "%d", &pid);
printf("pid = %d\n", pid);
char filename[1000];
sprintf(filename, "/proc/%d/stat", pid);
FILE *f = fopen(filename, "r");
int unused;
char comm[1000];
char state;
int ppid;
fscanf(f, "%d %s %c %d", &unused, comm, &state, &ppid);
printf("comm = %s\n", comm);
printf("state = %c\n", state);
printf("parent pid = %d\n", ppid);
fclose(f);
}
现在,如果我编译该文件并运行./a.out 29519
,我会得到
pid = 29519
comm = (vim)
state = S
parent pid = 5997
这是否为您提供了足够的信息以开始使用?
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.