操作系统之处理器管理的概念

一、处理器管理的概念

在现代操作系统中,处理器的分配和运行都是以进程为基本单位的,因而对处理器的管理也可以视为对进程的管理。进程是程序的一次执行过程。

处理器管理包括以下功能。

1.1. 进程控制

进程控制的主要任务就是为程序创建进程,撤销已结束的进程,以及控制进程在运行过程中的状态转换。在操作系统中,通常是利用若干条进程控制原语或系统调用,来实现进程的控制。所谓“原语”是指用以完成特定功能的、具有“原子性”的一个过程。

1.2. 进程同步

进程同步的主要任务是对众多的进程运行进行协调。

协调方式有两种:

(1)进程互斥方式

进程在对临界资源访问时,应采用互斥方式,也就是当一个进程访问临界资源时,另一个要访问该临界资源的进程必须等待;当获取临界资源的进程释放临界资源后,其他进程才能获取临界资源。这种进程之间的相互制约关系称为互斥。

对于进程互斥,最简单的实现方式就是设置锁,通过加锁、解锁实现互斥。

(2)进程同步方式

相互合作的进程,由同步机构对它们的执行次序加以协调。也就是前一个进程结束,后一个进程才能开始;前一个进程没有结束,后一个进程就不能开始。这种进程之间的相互合作关系称为同步。

在系统中,进程的同步可以有多种实现方法,其中,最常用的方法是信号量机制。

1.3. 进程通信

进程通信的任务就是用来实现相互合作进程之间的信息交换。

(1)直接通信方式

当相互合作的进程处于同一台计算机系统时,通常采用直接通信方式。由源进程利用发送命令直接将消息发送到目标进程的消息队列上,然后由目标进程利用接收命令从其消息队列中取出消息。

(2)间接通信方式

当相互合作的进程处于不同计算机系统时,通常采用间接通信方式。由源进程利用发送命令将信息发送到一个专门存放消息的中间实体中,然后由目标进程利用接收命令从中间实体中取出消息。这个中间实体通常称为“邮箱”,相应的通信系统称为电子邮件系统。

1.4. 处理器调度

一个批处理作业从进入系统并驻留在外存的后备队列上开始,直至作业运行完毕,可能要经历下述三级调度。

(1)高级调度

它又称为作业调度、长程调度或宏观调度,它的功能是按照某种原则把外存上处于后备队列中的那些作业调入内存,并为它们创建进程、分配必要的资源,然后再将新创建的进程排在就绪队列上,准备执行。

在批处理系统中有高级调度,而在分时系统中一般无高级调度。

(2)低级调度

它通常又称进程调度、短程调度或微观调度,它的功能是按照某种原则决定就绪队列中的哪个进程应获得处理机,再由分配程序执行处理机分配给该进程的具体动作。

进程调度是操作系统中最基本的调度,在批处理系统和分时系统中都必须配置它。

(3)中级调度

中级调度又称中程调度或交换调度。它负责内外存之间的进程对换,以解决内存紧张的问题,提高内存利用率和系统吞吐量。

上述三级调度的关系如下图所示。

二、程序执行

程序执行是指程序在计算机中的运行过程。程序的执行可以用前趋图表示,程序的执行方式有顺序执行和并发执行两种。

1. 前趋图

前趋图是一个有向无循环图。图中的每个节点可用于表示一条语句、一个程序段等;节点间的有向边表示在两个节点之间存在的前趋关系。如Pi→Pj,称Pi是Pj的前趋,而Pj是Pi的后继。在前趋图中,没有前趋的节点称为初始节点,没有后继的节点称为终止节点。应当注意的是,前趋图中不能存在循环。

在上图所示的前趋图中存在下述前趋关系:

P1→P2,P1→P3,P2→P4,P3→P4,P4→P5。

具有九个结点的前趋图

上图存在前趋关系:

Ii→Ci→Pi

p1→p2, p1→p3, p1→p4, p2→p5, p3→p5, p4→p6, p4→p7, p5→p8, p6→p8, p7→p9, p8→p9

也可以表示为:

P={P1,P2,P3,P4,P5,P6,P7,P8,P9}

2. 程序的顺序执行

(1)程序顺序执行的概念

一个程序通常可分为多个程序段,它们必须按照某种先后次序执行,仅当前一操作执行完后,才能执行后继操作。这里,我们用结点(Node)代表各程序段的操作,用I代表输入操作,C为计算操作,P为打印操作,用箭头表示其操作顺序 

(2)程序顺序执行的特征

①顺序性。严格按照程序所规定的顺序执行。

②封闭性。程序在封闭的环境下执行,其执行结果不受外界因素的影响。

③确定性。程序执行的结果与它的执行速度无关,不会影响到最终结果。

④可再现性。只要程序执行的环境和初始条件相同,都将获得相同的结果。

3. 程序的并发执行

(1)程序并发执行的概念

在处理一批程序时,它们之间有时并不存在严格的执行次序,可以并发执行。

程序并发执行时的前趋图,如下图所示。


I2、C1可以并发执行

I3、C2、P1可以并发执行。

对于具有下述四条语句的程序段:

S1: a :=x十2

S2:b:=y十4

S3:c:=a十b

S4:d:=c+b

四条语句的前趋图:


(2)程序并发执行的特征

①间断性。在程序并发执行时,它们之间共享资源或相互合作,形成了相互制约的关系,表现为“执行—暂停执行—执行”的间断性活动规律。

②失去封闭性。程序并发执行时,多个程序共享系统中的各种资源,致使程序的运行失去了封闭性。这样,一个程序在执行时,必然会受到其他程序的影响。

③不可再现性。即使并发程序执行的环境和初始条件相同,程序多次执行或以不同的方式执行都可能获得不相同的结果。

④资源共享性。系统中的硬件资源(CPU、内存和I/O设备等)和软件资源(系统程序和数据集等)为多个用户或作业共同使用。

⑤程序和计算不再一一对应。


例如:购买飞机票问题。

假定一个飞机订票系统有两个终端,分别运行两个程序段P1和P2,该系统公共数据库中一些单元Aj(j=1,2,…)分别存放某月某日某次航班的余票数,而x1与x2表示P1和P2执行时所用的工作单元。飞机售票程序如下:

Process  Pi(i=1,2)

Var xi:integer;

{

按旅客订票要求找到Aj

xi =Aj

if  xi>=1

  { xi = xi-1;

   Aj = xi;

输出一张票;

   }

Else

{输出信息“票已售完!”;

    }

}

由于P1、P2是两个可同时执行的并发程序,在该系统中,它们共享一批票数资源,因此,可能出现如下所示的运行情况:

P1:x1 =Aj

P2:x2 =Aj

P2:x2 =x2-1,Aj = x2 输出一张票

P1:x1 =x1-1,Aj = x1 输出一张票

显然,此时出现了把同一张票卖给两个旅客的情况,两个旅客各得一张票,但Aj的值实际上只减去1,造成余票数的不正确,这是不能允许的。为此,操作系统中必须对并发程序加以协调和控制,无论并发程序以怎样的速度向前推进,出现何种交叉情形,其程序的运行结果应当是唯一的、正确的。

 4.并发与顺序的比较

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

推荐阅读更多精彩内容