程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> C++ >> 關於C++ >> linux依據pid獲得過程名和獲得過程pid(c說話獲得pid)

linux依據pid獲得過程名和獲得過程pid(c說話獲得pid)

編輯:關於C++

linux依據pid獲得過程名和獲得過程pid(c說話獲得pid)。本站提示廣大學習愛好者:(linux依據pid獲得過程名和獲得過程pid(c說話獲得pid))文章只能為提供參考,不一定能成為您想要的結果。以下是linux依據pid獲得過程名和獲得過程pid(c說話獲得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法式中完成上述進程


#include <sys/types.h>
#include <dirent.h>
#include <stdio.h>
#include <string.h>

#define BUF_SIZE 1024

void getPidByName(char* task_name)
{
    DIR *dir;
    struct dirent *ptr;
    FILE *fp;
    char filepath[50];//年夜小隨便,能裝下cmdline文件的途徑便可
    char cur_task_name[50];//年夜小隨便,能裝下要辨認的敕令行文本便可
    char buf[BUF_SIZE];
    dir = opendir("/proc"); //翻開途徑
    if (NULL != dir)
    {
        while ((ptr = readdir(dir)) != NULL) //輪回讀取途徑下的每個文件/文件夾
        {
            //假如讀取到的是"."或許".."則跳過,讀取到的不是文件夾名字也跳過
            if ((strcmp(ptr->d_name, ".") == 0) || (strcmp(ptr->d_name, "..") == 0))            
            continue;
            if (DT_DIR != ptr->d_type)
              continue;

            sprintf(filepath, "/proc/%s/status", ptr->d_name);//生成要讀取的文件的途徑
            fp = fopen(filepath, "r");//翻開文件
            if (NULL != fp)
            {
                if( fgets(buf, BUF_SIZE-1, fp)== NULL ){
                fclose(fp);
                continue;
             }
            sscanf(buf, "%*s %s", cur_task_name);

                //假如文件內容知足請求則打印途徑的名字(即過程的PID)
                if (!strcmp(task_name, cur_task_name))
                printf("PID:  %s\n", ptr->d_name);
                fclose(fp);
            }

        }
        closedir(dir);//封閉途徑
    }
}

void getNameByPid(pid_t pid, char *task_name) {
    char proc_pid_path[BUF_SIZE];
    char buf[BUF_SIZE];

    sprintf(proc_pid_path, "/proc/%d/status", pid);
    FILE* fp = fopen(proc_pid_path, "r");
    if(NULL != fp){
        if( fgets(buf, BUF_SIZE-1, fp)== NULL ){
            fclose(fp);
        }
        fclose(fp);
        sscanf(buf, "%*s %s", task_name);
    }
}

void main(int argc, char** argv)
{
    char task_name[50];
    pid_t pid = getpid();

    printf("pid of this process:%d\n", pid);
    getNameByPid(pid, task_name);

    /*
    strcpy(task_name, argv[0]+2);
    printf("task name is %s\n", task_name);
    getPidByName(task_name);
    */
    printf("task name is %s\n", task_name);
    getPidByName(task_name);
    sleep(15);
}

運轉成果:

進入/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

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved