软件设计师考试 | 第四章 操作系统知识 | 进程管理

(一)基本概念

进程管理也称为处理机管理。

进程是资源分配和独立运行的基本单位。

1.程序与进程

程序顺序执行的特征:

  • 顺序性
  • 封闭性
  • 可再现性

程序并发执行的特征:

  • 失去了程序的封闭性
  • 程序和机器的执行程序的活动不再一一对应
  • 并发程序间的相互制约性

2.进程的组成

进程 是程序的一次执行,该程序可以和其他程序并发执行。
进程通常是由程序、数据和进程控制块(PCB)组成的。

3.进程的状态及其状态间的切换

  • 三态模型:运行、就绪、阻塞
  • 五态模型:新建、就绪、运行、阻塞、终止
  • 具有挂起状态的进程状态及其转换:活跃就绪、静止就绪、活跃阻塞、静止阻塞

(二)进程的控制

进程控制 就是对系统中的所有进程从创建到消亡的全过程实施有效的控制。

原语 是指若干条机器指令组成的,用于完成特定功能的程序段。
原语在执行时不能被分割。


(三)进程间的通信

进程通信 是指各个进程交换信息的过程。

1.同步与互斥

同步 是合作进程间的直接制约问题,互斥是申请临界资源进程间的间接制约问题。

进程的同步: 是指在系统中一些需要相互合作,协同工作的进程,这样的相互联系称为进程的同步。

进程间的互斥: 是指系统中多个进程因争用临界资源而互斥执行。

临界资源: 在多道程序系统环境中,各进程可以共享各类资源,但有些资源一次只能供一个进程使用,称为临界资源,如打印机、共享变量和表格等。

临界区: 是进程中对临界资源实施操作的那段程序。

对互斥临界区管理的原则:

  • 有空即进
  • 无空则等
  • 有限等待
  • 让权等待

2.信号量机制

信号量机制是一种有效的进程同步与互斥工具。
信号量机制主要有:整型信号量、记录型信号量、信号量集机制。

信号量S的物理意义:S>=0表示某资源的可用数,若S<0,则其绝对值表示阻塞队列中等待该资源的进程数。

PV操作是实现进程同步与互斥的常用方法。
P操作表示申请一个资源,V操作表示释放一个资源。

P操作: S:=S-1,若S>=0,则执行P操作的进程继续执行;若S<0,则置该进程为阻塞状态(因为无可用资源),并将其插入阻塞队列。
V操作: S:=S+1,若S>0,则执行V操作的进程继续执行;若S<=0,则从阻塞状态唤醒一个进程,并将其插入就绪队列,然后执行V操作的进程继续。

利用PV操作实现进程的互斥与同步。

3.高级通信原语

高级通信方式分为:

  • 共享存储模式,相互通信的进程共享某些数据结构(或存储区)实现进程之间的通信;
  • 消息传递模式,直接利用系统提供的一组通信命令来实现通信;
  • 管道通信,管道是指用于连接一个读进程和一个写进程,以实现它们之间通信的共享文件。

(四)管程

1.管程的引入

管程: 采用资源集中管理的方法,将系统中的资源用某种数据结构抽象地表示出来。
管程由一些共享数据、一组能为并发进程所执行的作用在共享数据上的操作的集合、初始代码及存取权组成。

2.管程的结构

每一个管程都有一个名字以供标识。


(五)进程调度

进程调度方式是指当有更高优先级的进程到来时如何分配CPU
调度方式分为:

  • 可剥夺,当有更高优先级的进程到来时,强行将正在运行进程的CPU分配给高优先级的进程;
  • 不可剥夺。当有更高优先级的进程到来时,必须等待正在运行进程自动释放占用的CPU,然后将CPU分配给更高优先级的进程。

1.三级调度

三级调度:

  • 高级调度(长调度、作业调度、接纳调度)
  • 中级调度(中程调度、对换调度)
  • 低级调度(短程调度、进程调度)

2.调度算法

常用的调度算法有:

  • 先来先服务(FCFS
  • 时间片轮转
    • 固定时间片
    • 可变时间片
  • 优先级调度
    • 静态优先级
    • 动态优先级
  • 多级反馈调度

3.进程优先级确定

需要考虑的情况:

  • 对于I/O型进程,让其进入最高优先级队列,以及时响应需要I/O交互的进程。通常执行一个小的时间片,在该时间片内要求可处理完一次I/O请求的数据,然后转入到阻塞队列。
  • 对于计算型进程,每次都执行完时间片后进入更低级队列,最终采用最大时间片来执行,以减少调度次数。
  • 对于I/O次数不多,主要是CPU处理的进程,在I/O完成后,返回优先I/O请求时离开的队列,以免每次都回到最高优先级队列后再逐次下降。
  • 为适应一个进程在不同时间段的运行特点,I/O完成时,提高优先级;时间片用完时,降低优先级。

(六)死锁

死锁: 指两个以上的进程互相都要求对方已经占有的资源导致无法继续运行下去的现象。

1.死锁产生的原因及4个必要条件

  • 互斥条件
  • 请求保持条件
  • 不可剥夺条件
  • 环路条件

2.死锁的处理

  • 鸵鸟策略
  • 预防策略
  • 避免策略
  • 检测与解除死锁

(七)线程

传统的进程有两个基本属性:

  • 可拥有资源的独立单位
  • 可独立调度和分配的基本单位

引入线程后,将传统进程的两个基本属性分开,线程作为调度和分配的基本单位,进程作为独立分配资源的单位。

线程分类:

  • 用户级线程,不依赖于内核,该类线程的创建、撤销和切换都不利用系统调用来实现;
  • 内核支持线程,依赖于内核,即无论是在用户进程中的线程,还是在系统中的线程,它们的创建、撤销和切换都利用系统调用来实现。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容