Я работаю над солярисом.
Я знаю, что если запущен процесс, существует файл с именем /proc/<PID>/status
, где <PID>
это идентификатор процесса, и он содержит поле с именем state
,
В качестве примера я использовал мой процесс оболочки:
> ps
PID TTY TIME CMD
18671 0:01 tcsh
чей идентификатор процесса 18671.
Я написал простую программу на C для извлечения этой информации:
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/procfs.h>
#include <sys/fcntl.h>
static void get_status (pid_t pid)
{
char procpath[100];
char buf[100];
int pfd;
char State[100];
char Name[100];
prstatus_t * pms;
FILE *proc;sprintf(procpath, "/proc/%d/status", pid);
proc = fopen(procpath,"r");
if (proc) {
printf("Open Successful\n");
fgets(buf,256,proc); sscanf(buf,"Name:\t%s",Name);
fgets(buf,256,proc); sscanf(buf,"State:\t%c",State);
}
printf("%s",Name);
printf("%s",State);
}
int main(int argc, char **argv)
{
get_status(18671);
}
Это не производит никакого вывода:
> ./a.out
Open Successful
>
В онлайн-материале для procfs говорится, что мы можем просто proc/<pid>/status
и проверьте состояние процесса.
Но в моем случае это бинарный файл. Я никогда не видел, чтобы это упоминалось где-то, что это двоичный файл.
Есть ли способ, где я мог бы использовать простую программу на C, чтобы получить состояние текущего процесса?
Решение C ++ также будет приемлемым.
Это структура, которую вы должны прочитать из / proc /pid
/статус:
typedef struct pstatus {
int pr_flags; /* flags (see below) */
int pr_nlwp; /* number of active lwps in the process */
pid_t pr_pid; /* process id */
pid_t pr_ppid; /* parent process id */
pid_t pr_pgid; /* process group id */
pid_t pr_sid; /* session id */
id_t pr_aslwpid; /* historical; now always zero */
id_t pr_agentid; /* lwp id of the /proc agent lwp, if any */
sigset_t pr_sigpend; /* set of process pending signals */
uintptr_t pr_brkbase; /* address of the process heap */
size_t pr_brksize; /* size of the process heap, in bytes */
uintptr_t pr_stkbase; /* address of the process stack */
size_t pr_stksize; /* size of the process stack, in bytes */
timestruc_t pr_utime; /* process user cpu time */
timestruc_t pr_stime; /* process system cpu time */
timestruc_t pr_cutime; /* sum of children's user times */
timestruc_t pr_cstime; /* sum of children's system times */
sigset_t pr_sigtrace; /* set of traced signals */
fltset_t pr_flttrace; /* set of traced faults */
sysset_t pr_sysentry; /* set of system calls traced on entry */
sysset_t pr_sysexit; /* set of system calls traced on exit */
char pr_dmodel; /* data model of the process (see below) */
char pr_pad[3];
taskid_t pr_taskid; /* task id */
projid_t pr_projid; /* project id */
int pr_nzomb; /* number of zombie lwps in the process */
zoneid_t pr_zoneid; /* zone id */
int pr_filler[15]; /* reserved for future use */
lwpstatus_t pr_lwp; /* status of the representative lwp */
} pstatus_t;
Обратите внимание, что это определено в заголовочном файле procfs.h. Объявить pstatus_t
переменная и читать sizeof(pstatus_t)
байты в эту переменную.
Совет: также недоступно через ls
Вы также можете использовать /proc/self/psinfo
читать psinfo о самостоятельном процессе.
Других решений пока нет …