P9 LinuxC 进程概述 终端启动的程序父进程是终端

 前言

                                     

🎬 个人主页:@ChenPi

🐻推荐专栏1: 《C++_@ChenPi的博客-CSDN博客》✨✨✨ 

🔥 推荐专栏2: 《Linux C应用编程(概念类)_@ChenPi的博客-CSDN博客》✨✨✨

🛸推荐专栏3: ​​​​​​《链表_@ChenPi的博客-CSDN博客 》 ✨✨✨
🌺本篇简介  :  这一章我们学习一下Linux中非常重要的一部分——进程

Linux 是一个多用户多任务的操作系统,每个用户可以同时运行多个程序

进程是程序运行的主体,包括进程的创建,调度和消亡的整个过程

当用户执行一个指令或者启动一个程序时,就创建了一个进程

一个运行的程序也可能有多个进程。

每个进程将被分配各种资源           

01 Linux 下的进程控制块(PCB)

进程是Linux系统的基本调度单位。在Linux系统中,进程是通过进程控制块来描述的。

在Linux进程控制块由task_struct数据结构实现,它记录了以下几个类型的信息:

  1. 状态信息。例如,这个进程处于可执行状态、休眠、挂起等。
  2. 性质。由于Linux有很多变种,进程有自己独特的性质。
  3. 资源。资源的链接,如内存,还有资源的限制和权限等。
  4. 组织。例如,按照家族关系建立起来的树(父进程,子进程等)。

每个进程用一个task struct数据结构来表示。

数组task包含指向系统中所有task_struct结构的指针。

系统中的最大进程数目受task数组大小的限制,默认值一般为512。

创建新进程时,Linux将从系统内存中分配一个task_struct结构并将其加入task数组。

如果想看这个结构体可以进入下面链接

Linux PCB(进程控制块) 详解-CSDN博客

我觉得讲的也很清楚

当前运行进程的结构用current 指针来指示。

进程控制块(Process Control Block,PCB)是用来记录进程状态及其他相关信息的数据结构。

PCB是进程存在的唯一标志,PCB存在则进程存在。

系统创建进程时会产生一个 PCB,撤销进程时,PCB也自动消失。

2.进程的标识

PCB的内容丰富,其中的进程标识包括进程号、用户标识、用户组标识、进程时间、资源利用情况等。

这里只介绍其中最主要的进程号,也就是PID。

PID唯一的标识一个进程。除了进程的PID外,进程的父进程号(PPID)也是一个主要的标识。

当父进程终止时,子进程也随之而终止。

但子进程终止,父进程并不一定终止。

PID 和 PPID都是一个非零正整数。

在Linux中可以通过系统调用getpid 得到进程的 ID,

而getppid可以得到父进程(创建调用该函数进程的进程)的ID。

03获取进程PID号 —— getpid()

Linux 系统下的每一个进程都有一个进程号(process ID,简称 PID),

进程号是一个正数,用于唯一标 识系统中的某一个进程。

在应用程序中,可通过系统调用 getpid()来获取本进程的进程号,其函数原型如下所示:

#include <sys/types.h> 
#include <unistd.h> 
 
pid_t getpid(void); 

返回值: 成功返回当前进程的ID号,失败返回-1

应用代码测试:

#include <stdio.h> 
#include <stdlib.h> 
#include <sys/types.h> 
#include <unistd.h> 
 
 
int main(void) 
 
{ 
 pid_t pid = getpid(); 
 printf("本进程的 PID 为: %d\n", pid); 
 exit(0); 
 
} 

ps aux|grep ./a.out

通过PS指令我们可以看到我们运行的./a.out的这个进程是9910

然后我们看我们代码打印出来的数字,也是9910

所以getpid这个系统调用是返回当前进程的ID号

04 getppid()获取父进程PID号


除了 getpid()用于获取本进程的进程号之外,还可以使用 getppid()系统调用获取父进程的进程号,其函 数原型如下所示:

#include <sys/types.h> 
#include <unistd.h> 
 
pid_t getppid(void); 

返回值:返回父进程的PID号 

#include <stdio.h> 
#include <stdlib.h> 
#include <sys/types.h> 
#include <unistd.h> 
 
int main(void)  
{ 
 pid_t pid = getpid(); //获取本进程 pid 
 
 printf("本进程的 PID 为: %d\n", pid); 
 
 pid = getppid(); //获取父进程 pid 
 
 printf("父进程的 PID 为: %d\n", pid); 
 
 exit(0); 
 
} 

 

所以到底是不是这样呢?

我们使用KILL 指令试一下,看把终端杀了会怎么样

可以看到程序的父进程是终端,因为这个程序是依托于终端运行的 

所以它的父进程是终端,父进程被杀死后,程序也停止运行了

  • 34
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
进程调度算法是操作系统中的一个重要部分,可以通过模拟实现来加深对算法的理解。下面以先到先服务(FCFS)算法为例,介绍如何进行模拟实现。 首先,我们需要定义进程的数据结构,包括进程的名称、到达时间、需要执行的时间、开始执行时间、完成时间、等待时间和周转时间等信息。代码如下: ```python class Process: def __init__(self, name, arrival_time, burst_time): self.name = name self.arrival_time = arrival_time self.burst_time = burst_time self.start_time = 0 self.finish_time = 0 self.waiting_time = 0 self.turnaround_time = 0 ``` 接下来,我们需要定义一个函数来模拟FCFS算法。该函数接收一个进程列表作为输入,按照到达时间对进程进行排序,然后依次执行每个进程,计算出每个进程的开始执行时间、完成时间、等待时间和周转时间等信息。代码如下: ```python def fcfs(processes): # 按照到达时间排序 processes.sort(key=lambda x: x.arrival_time) # 执行进程 current_time = 0 for p in processes: p.start_time = current_time p.finish_time = p.start_time + p.burst_time p.waiting_time = p.start_time - p.arrival_time p.turnaround_time = p.finish_time - p.arrival_time current_time = p.finish_time # 输出结果 print("进程名 到达时间 执行时间 开始时间 完成时间 等待时间 周转时间") for p in processes: print("{0}\t{1}\t{2}\t{3}\t{4}\t{5}\t{6}".format(p.name, p.arrival_time, p.burst_time, p.start_time, p.finish_time, p.waiting_time, p.turnaround_time)) ``` 最后,我们可以定义一个测试函数来生成一些进程并调用fcfs函数进行模拟。代码如下: ```python import random def test_fcfs(): # 生成10个进程 processes = [] for i in range(10): name = "P" + str(i + 1) arrival_time = random.randint(0, 9) burst_time = random.randint(1, 5) processes.append(Process(name, arrival_time, burst_time)) # 调用FCFS算法进行模拟 fcfs(processes) test_fcfs() ``` 运行结果如下: ``` 进程名 到达时间 执行时间 开始时间 完成时间 等待时间 周转时间 P1 0 3 0 3 0 3 P2 0 4 3 7 3 7 P3 0 2 7 9 7 9 P4 1 4 9 13 8 12 P5 1 2 13 15 12 14 P6 2 3 15 18 13 16 P7 3 1 18 19 15 16 P8 4 2 19 21 15 17 P9 6 2 21 23 15 17 P10 7 1 23 24 16 17 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@ChenPi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值