【操作系统】第七课

这篇博客详细介绍了操作系统的进程概念,包括进程的定义、组成、特点、状态变化模型以及PCB(进程控制块)等内容。还讨论了进程与程序的关系、进程的生命周期、进程间通信和同步,以及线程的优势和实现方式。文章强调了进程的动态性和并发性,以及线程在减少并发执行时空开销方面的作用。
摘要由CSDN通过智能技术生成

课程来源《操作系统_清华大学(向勇、陈渝)》

进程描述、进程状态、线程、进程间通信、进程互斥与同步、死锁

进程描述:进程定义、进程的组成、进程的特点、进程控制结构

进程状态:进程的生命周期、进程状态变化模型、进程挂起模型

1.进程的定义

OS系统从只能跑一个程序到能跑多个。

进程可以描述程序的执行过程。

进程:一个具有一定独立功能的程序在一个数据集合上的一次动态执行过程(操作系统把写的程序调入到内存中之后,让程序可以执行起来,也就是通过CPU执行程序中的一条条指令,然后对相应的数据进行处理,可以完成一定功能,这个过程是一个动态的过程,所以进程可以理解为静态的程序通过操作系统放入内存中,让CPU执行起来,形成一个动态的执行过程,这个执行过程就可以理解为进程)。

静态的程序通过操作系统放入内存中,让CPU执行起来,形成一个动态的执行过程,这个执行过程就可以理解为进程。

在这里插入图片描述

只有当一个程序被OS加载到内存中,cpu对其执行时,这个过程是动态的,称为进程。

2.进程的组成

进程包含了正在运行的一个程序的所有状态信息 :
 程序的代码
 程序处理的数据
 要知道现在执行哪条指令,程序计数器中的值指示将运行的指令。
CPU寄存器会动态变化,一组通用寄存器的当前值,堆,栈等;
 各种系统资源,文件,内存,外存,网络

进程与程序的联系 :(进程是一个动态的执行过程,程序是一个静态的代码)
1.程序是进程的基础,代码控制操作,可以多次执行程序,
2.程序的每次运行构成不同的进程;(因为每次程序调用的过程使用数据可能不同,进程是一个动态过程,包含很多状态信息,包括数据和各种资源)
3.进程是程序功能的体现;
4.通过多次执行——某一个程序可对应多个进程;
5.通过调用关系——某一个进程可包括多个程序。

进程与程序的区别:
1.程序是静态的,有序代码的集合;
进程是动态的,进程是程序的执行,可以有核心态/用户态,写的代码都是用户态,但有些操作比如读写文件只能由OS完成,OS代表进程在内核中执行,此时为核心态;
2.进程是暂时的,是状态变化的过程,程序永久,程序可长久保存;
3.组成不同,进程包括程序,数据(可能变化),进程控制块(即进程状态信息)

例子:
食谱 = 程序;科学家 = CPU;原料 = 数据;做蛋糕 = 进程。
所以,进程可以看作是一件事,做这件事的方法是程序规定的,除此之外我们需要CPU去做这件事,当然我们也需要原料(数据)

当CPU做蛋糕时候突然有时,CPU可以在食谱(程序)上做个标记,把状态信息记录了起来,当再次回来的时候,可以根据记录继续做蛋糕了。【这个过程就是进程间的切换】

3.进程的特点

1.动态性,可动态地创建,结束进程;
2.并发性(在一段时间内有多个程序在执行,不同于并行,是一个时间点有多个在跑,需多个CPU即多核,进程可以被独立调度并占用处理机运行):
3.独立性,正确性不受影响(通过OS给不同的进程分配不同页表,保证正确性/独立性);
4.制约性,因访问共享数据/资源或进程间同步产生制约,要同步互斥;

在这里插入图片描述

描述进程的数据结构:进程控制块,PROCESS control block( PCB )

OS给每个进程都维护了一个PCB,保存与之有关的所有状态信息。

4.进程控制结构

PCB进程控制块:进程存在的唯一标识,操作系统管理控制进程运行所用的信息集合,描述进程的基本情况和运行变化的过程。

用PCB的生成,回收,组织管理来完成进程的创建、终止

【实验目的】 1. 理解进程的概念,熟悉进程的组成; 2. 用高级语言编写和调试一个进程调度程序,以加深对进程调度算法的理解。 【实验准备】 1. 几种进程调度算法  短进程优先调度算法  高优先权优先调度算法  先来先服务调度算法  基于间片的轮转调度算法 2. 进程的组成  进程控制块(PCB)  程序段  数据段 3. 进程的基本状态  就绪W(Wait)  执行R(Run)  阻塞B(Block) 【实验内容】 1. 例题 设计一个有 N个进程共行的进程调度程序。 进程调度算法:采用最高优先数优先的调度算法(即把处理机分配给优先数最高的进程)和先来先服务算法。 每个进程一个进程控制块(PCB)表示。进程控制块可以包含如下信息:进程名、优先数、到达间、需要运行间、已用CPU间、进程状态等等。进程的优先数及需要的运行间可以事先人为地指定(也可以由随机数产生)。进程的到达间为进程输入的间。进程的运行间以间片为单位进行计算。每个进程的状态可以是就绪 W(Wait)、运行R(Run)、或完成F(Finish)三种状态之一。就绪进程获得 CPU后都只能运行一个间片。用已占用CPU间加1来表示。如果运行一个间片后,进程的已占用 CPU间已达到所需要的运行间,则撤消该进程,如果运行一个间片后进程的已占用CPU间还未达所需要的运行间,也就是进程还需要继续运行,此应将进程的优先数减1(即降低一级),然后把它插入就绪队列等待CPU。每进行一次调度程序都打印一次运行进程、就绪队列、以及各个进程的 PCB,以便进行检查。重复以上过程,直到所要进程都完成为止。 4. 实验题目  编写并调试一个模拟的进程调度程序,采用“最高优先数优先”调度算法对五个进程进行调度。“最高优先数优先”调度算法的基本思想是把CPU分配给就绪队列中优先数最高的进程。静态优先数是在创建进程确定的,并在整个进程运行期间不再改变。动态优先数是指进程的优先数在创建进程可以给定一个初始值,并且可以按一定原则修改优先数。例如在进程获得一次CPU后就将其优先数减少1。或者,进程等待的间超过某一增加其优先数的值,等等。  编写并调试一个模拟的进程调度程序,采用“轮转法”调度算法对五个进程进行调度。轮转法可以是简单轮转法、可变间片轮转法,或多队列轮转法。简单轮转法的基本思想是:所有就绪进程按 FCFS排成一个队列,总是把处理机分配给队首的进程,各进程占用CPU的间片相同。如果运行进程用完它的间片后还为完成,就把它送回到就绪队列的末尾,把处理机重新分配给队首的进程。直至所有的进程运行完毕。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值