『 Linux 』使用fork函数创建进程与进程状态的查看(上)

简介: 『 Linux 』使用fork函数创建进程与进程状态的查看(上)



🖥️ 前言 🖥️

『 Linux 』进程概念 中了解到了操作系统对于进程的管理也是使用了"先描述后组织的方式",且提到可以使用以下方式来查看进程:

  • ps
    只能查看当前渠道内的进程,若是需要查看所有进程应该加上修饰,即使用ps axj | grep id_PID来查看进程;
  • top
    top命令更像是Windows下的任务管理器,一般用来观察内存当中占用较大的那个进程;
  • ls /proc
    使用ls命令以目录的形式来查看进程;

🖥️ 通过系统调用获取进程标识符 🖥️

💻 进程标识符PID

在Linux中不仅可以使用以上方式查看进程,也可以通过系统调用的方式使程序获取到当前进程标识符;

在Linux中有一个头文件为这个头文件提供了一些关于系统调用和底层操作的有关函数;这个头文件包含了许多操作系统接口访问的重要功能;

而在这个头文件中存在个函数,这个函数为pid_t getpid(),其中这个函数的返回值类型pid_t可以看成是一个unsigned int类型;

该函数能够使该程序获取自身的进程标识符PID;

示例:

#include<iostream>
#include<unistd.h>
using namespace std;
void test1(){
  while(1){
  cout<<"the PID is  "<<getpid()<<endl;//打印出该进程的PID
  cout<<"##########################"<<endl;
  sleep(1);
  }
}
int main()
{
  test1();
  return 0;
}

当运行这个程序之后这个进程将以间隔1s的速度打印出以上内容,同时带上PID;

使用ps查看该进程的状态:

$ ps axj | head -1 && ps axj | grep 32391 | grep -v grep
 PPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
31335 31336 31336 31336 pts/1    32391 Ss    1002   0:00 -bash
31336 32391 32391 31336 pts/1    32391 S+    1002   0:00 ./myproc

当使用kill -9 32391命令时向该进程发送9号信号将该进程杀死;

the PID is  32391
##########################
the PID is  32391
##########################
the PID is  32391
##########################
Killed
$

💻 父进程标识符PPID

在该头文件中一样存在着一个函数可以使得该程序获取当前进程的父进程的PID,也就是PPID;

#include<iostream>
#include<unistd.h>
using namespace std;
void test1(){
  while(1){
  cout<<"the PID is  "<<getpid()<<endl;//打印出该进程的PID
    cout<<"the PPID is  "<<getppid()<<endl;//打印出该进程父进程的PID
  cout<<"##########################"<<endl;
  sleep(1);
  }
}
int main()
{
  test1();
  return 0;
}

当程序运行时:

the PID is  886
the PPID is  31336
##########################
the PID is  886
the PPID is  31336
##########################
the PID is  886
the PPID is  31336
##########################

使用ps也能直接的观察到该进程的PID与PPID从而进行验证;

ps axj | head -1 && ps axj | grep 886 | grep -v grep
 PPID   PID  PGID   SID TTY      TPGID STAT   UID   TIME COMMAND
31336   886   886 31336 pts/1      886 S+    1002   0:00 ./myproc
31335 31336 31336 31336 pts/1      886 Ss    1002   0:00 -bash

然而从该处可以直接看到其实该进程的父进程就是一个-bash命令行解释器;


『 Linux 』使用fork函数创建进程与进程状态的查看(下)https://developer.aliyun.com/article/1424456

相关文章
|
Web App开发 Linux 程序员
获取和理解Linux进程以及其PID的基础知识。
总的来说,理解Linux进程及其PID需要我们明白,进程就如同汽车,负责执行任务,而PID则是独特的车牌号,为我们提供了管理的便利。知道这个,我们就可以更好地理解和操作Linux系统,甚至通过对进程的有效管理,让系统运行得更加顺畅。
409 16
|
Shell Linux C语言
函数和进程之间的相似性
在一个C程序可以fork/exec另一个程序,其过程是先fork一个子进程,然后让子进程使用exec系列函数将子进程的代码和数据替换为另一个程序的代码和数据,之后子进程就用该程序的数据执行该程序的代码,从而达到程序之间相互调用的效果。在学了C语言、C++或是JAVA等高级语言,你会知道,在这些语言中的函数是可以相互进行见调用的,但是在学习了Linux的前面的知识后,你就会有意无意的认识到其实进程也是与函数有相同之处的,进程之间也是可以相互调用的。程序之间相互调用带来的好处之一。那么下面就将这部分内容扩展。
190 0
|
监控 Shell Linux
Linux进程控制(详细讲解)
进程等待是系统通过调用特定的接口(如waitwaitpid)来实现的。来进行对子进程状态检测与回收的功能。
301 0
|
存储 负载均衡 算法
Linux2.6内核进程调度队列
本篇文章是Linux进程系列中的最后一篇文章,本来是想放在上一篇文章的结尾的,但是想了想还是单独写一篇文章吧,虽然说这部分内容是比较难的,所有一般来说是简单的提及带过的,但是为了让大家对进程有更深的理解与认识,还是看了一些别人的文章,然后学习了学习,然后对此做了总结,尽可能详细的介绍明白。最后推荐一篇文章Linux的进程优先级 NI 和 PR - 简书。
368 0
|
存储 Linux Shell
Linux进程概念-详细版(二)
在Linux进程概念-详细版(一)中我们解释了什么是进程,以及进程的各种状态,已经对进程有了一定的认识,那么这篇文章将会继续补全上篇文章剩余没有说到的,进程优先级,环境变量,程序地址空间,进程地址空间,以及调度队列。
242 0
|
Linux 调度 C语言
Linux进程概念-详细版(一)
子进程与父进程代码共享,其子进程直接用父进程的代码,其自己本身无代码,所以子进程无法改动代码,平时所说的修改是修改的数据。为什么要创建子进程:为了让其父子进程执行不同的代码块。子进程的数据相对于父进程是会进行写时拷贝(COW)。
305 0
|
安全 Linux 调度
关于linux系统如何实现fork的研究(二)【转】
转自:http://www.aichengxu.com/linux/7166015.htm 本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 引言   前一篇关于linux系统如何实现fork的研究(一)通过代码已经说明了从用户态怎么通过软中断实现调用系统调用clone函数,而clone函数的精华copy_process函数就在此篇文章中进行分析。
1188 0
|
Linux C语言
关于linux系统如何实现fork的研究(一)【转】
转自:http://www.aichengxu.com/linux/4157180.htm 引言 fork函数是用于在linux系统中创建进程所使用,而最近看了看一个fork()调用是怎么从应用到glibc,最后到内核中实现的,这片文章就聊聊最近对这方面研究的收获吧。
1303 0
|
9月前
|
Linux 应用服务中间件 Shell
二、Linux文本处理与文件操作核心命令
熟悉了Linux的基本“行走”后,就该拿起真正的“工具”干活了。用grep这个“放大镜”在文件里搜索内容,用find这个“探测器”在系统中寻找文件,再用tar把东西打包带走。最关键的是要学会使用管道符|,它像一条流水线,能把这些命令串联起来,让简单工具组合出强大的功能,比如 ps -ef | grep 'nginx' 就能快速找出nginx进程。
993 1
二、Linux文本处理与文件操作核心命令
|
9月前
|
Linux
linux命令—stat
`stat` 是 Linux 系统中用于查看文件或文件系统详细状态信息的命令。相比 `ls -l`,它提供更全面的信息,包括文件大小、权限、所有者、时间戳(最后访问、修改、状态变更时间)、inode 号、设备信息等。其常用选项包括 `-f` 查看文件系统状态、`-t` 以简洁格式输出、`-L` 跟踪符号链接,以及 `-c` 或 `--format` 自定义输出格式。通过这些选项,用户可以灵活获取所需信息,适用于系统调试、权限检查、磁盘管理等场景。
610 137