在Linux中打印进程树的完整代码
时间: 2024-05-15 15:15:21 浏览: 63
以下是在Linux中打印进程树的完整代码:
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <dirent.h>
#include <sys/types.h>
#include <sys/stat.h>
#define MAX_PID_LEN 10
#define MAX_PATH_LEN 100
void print_tree(char *pid, int level);
int main(int argc, char *argv[]) {
if (argc != 2) {
printf("Usage: %s <pid>\n", argv[0]);
return -1;
}
print_tree(argv[1], 0);
return 0;
}
void print_tree(char *pid, int level) {
DIR *dir;
struct dirent *entry;
char path[MAX_PATH_LEN];
char new_pid[MAX_PID_LEN];
struct stat statbuf;
int i;
if (level == 0) {
printf("%s\n", pid);
}
sprintf(path, "/proc/%s/task", pid);
if ((dir = opendir(path)) == NULL) {
return;
}
while ((entry = readdir(dir)) != NULL) {
if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) {
continue;
}
sprintf(path, "/proc/%s/task/%s", pid, entry->d_name);
if (lstat(path, &statbuf) < 0) {
continue;
}
if (S_ISDIR(statbuf.st_mode)) {
for (i = 0; i < level + 1; i++) {
printf("| ");
}
printf("|-- ");
printf("%s\n", entry->d_name);
strncpy(new_pid, entry->d_name, MAX_PID_LEN);
print_tree(new_pid, level + 1);
}
}
closedir(dir);
}
```
该程序的主要思路是通过读取 `/proc` 目录下的进程信息来构建进程树。首先,程序接受一个进程 PID 作为命令行参数,并将其作为根节点打印出来。然后,程序遍历 `/proc/<pid>/task` 目录下的所有子目录,如果子目录是以数字命名的目录,就将其作为一个子节点打印出来,并递归打印其子节点。在打印子节点时,程序会在前面加上一些空格,以形成树状结构。
需要注意的是,程序中使用了 `lstat()` 函数来获取文件的元数据。这是因为 `/proc` 目录下的很多文件都是符号链接,如果直接使用 `stat()` 函数获取文件信息,会返回符号链接本身的信息,而不是链接指向的文件的信息。
阅读全文