您的位置:首页 > 其它

根据PID获取进程名 或者 根据进程名获取PID

2014-04-09 13:49 501 查看


根据PID获取进程名&根据进程名获取PID

Liunx中 通过进程名查找进程PID可以通过 pidof [进程名] 来查找。反过来 ,相同通过PID查找进程名则没有相关命令。

在linux根目录中,有一个/proc的VFS(虚拟文件系统),系统当前运行的所有进程都对应于该目录下的一个 以进程PID命名的文件夹 ,其中存放进程运行的N多信息。其中有一个status文件,cat显示该文件, 第一行的Name 即为进程名。

打开stardict程序,进程名为stardict;
shell中分别根据Pid获取进程名、根据进程名获取Pid
1)查找stardict的pid:pidof stardict
2)根据1)的pid查找进程名: grep "Name:" /proc/5884/status

应用:kill一个进程需要指定该进程的pid,所以我们需要先根据进程名找到pid,然后再kill;
   killall命令则只需要给定进程名即可,应该是封装了这个过程。

C程序中实现上述过程



1 #include <sys/types.h>
 2 #include <dirent.h>
 3 #include <stdio.h>
 4 #include <string.h>
 5 
 6 #define BUF_SIZE 1024
 7 
 8 void getPidByName(char* task_name)
 9 {
10     DIR *dir;
11     struct dirent *ptr;
12     FILE *fp;
13     char filepath[50];//大小随意,能装下cmdline文件的路径即可
14     char cur_task_name[50];//大小随意,能装下要识别的命令行文本即可
15     char buf[BUF_SIZE];
16     dir = opendir("/proc"); //打开路径
17     if (NULL != dir)
18     {
19         while ((ptr = readdir(dir)) != NULL) //循环读取路径下的每一个文件/文件夹
20         {
21             //如果读取到的是"."或者".."则跳过,读取到的不是文件夹名字也跳过
22             if ((strcmp(ptr->d_name, ".") == 0) || (strcmp(ptr->d_name, "..") == 0))             
            continue;
23             if (DT_DIR != ptr->d_type) 
24               continue;
25            
26             sprintf(filepath, "/proc/%s/status", ptr->d_name);//生成要读取的文件的路径
27             fp = fopen(filepath, "r");//打开文件
28             if (NULL != fp)
29             {
30                 if( fgets(buf, BUF_SIZE-1, fp)== NULL ){
31                 fclose(fp);
32                 continue;
33              }
34             sscanf(buf, "%*s %s", cur_task_name);
35         
36                 //如果文件内容满足要求则打印路径的名字(即进程的PID)
37                 if (!strcmp(task_name, cur_task_name))
38                 printf("PID:  %s\n", ptr->d_name);
39                 fclose(fp);
40             }
41            
42         }
43         closedir(dir);//关闭路径
44     }
45 }
46 
47 void getNameByPid(pid_t pid, char *task_name) {
48     char proc_pid_path[BUF_SIZE];
49     char buf[BUF_SIZE];
50 
51     sprintf(proc_pid_path, "/proc/%d/status", pid);
52     FILE* fp = fopen(proc_pid_path, "r");
53     if(NULL != fp){
54         if( fgets(buf, BUF_SIZE-1, fp)== NULL ){
55             fclose(fp);
56         }
57         fclose(fp);
58         sscanf(buf, "%*s %s", task_name);
59     }
60 }
61 
62 void main(int argc, char** argv)
63 {
64     char task_name[50];
65     pid_t pid = getpid();
66 
67     printf("pid of this process:%d\n", pid);
68     getNameByPid(pid, task_name);
69     
70     /*
71     strcpy(task_name, argv[0]+2);
72     printf("task name is %s\n", task_name);
73     getPidByName(task_name);
74     */
75     printf("task name is %s\n", task_name);
76     getPidByName(task_name);
77     sleep(15);
78 }




运行结果:




进入/proc/9674/status查看文件内容,一切对应。
Name: test

State: S (sleeping)

Tgid: 9674

Pid: 9674

PPid: 7438

TracerPid: 0

Uid: 1000 1000 1000 1000

Gid: 1000 1000 1000 1000

FDSize: 256

Groups: 4 24 27 30 46 112 124 1000

VmPeak: 4340 kB

VmSize: 4336 kB

VmLck: 0 kB

VmPin: 0 kB

VmHWM: 600 kB

VmRSS: 600 kB

VmData: 184 kB

VmStk: 136 kB

VmExe: 4 kB

VmLib: 1920 kB

VmPTE: 32 kB

VmSwap: 0 kB

Threads: 1

SigQ: 0/15776

SigPnd: 0000000000000000

ShdPnd: 0000000000000000

SigBlk: 0000000000000000

SigIgn: 0000000000000000

SigCgt: 0000000000000000

CapInh: 0000000000000000

CapPrm: 0000000000000000

CapEff: 0000000000000000

CapBnd: 0000001fffffffff

Seccomp: 0

Cpus_allowed: f

Cpus_allowed_list: 0-3

Mems_allowed: 00000000,00000001

Mems_allowed_list: 0

voluntary_ctxt_switches: 1

nonvoluntary_ctxt_switches: 4
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: