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

根据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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值