操作系统原理-方敏-进程与线程基本知识_第1页
操作系统原理-方敏-进程与线程基本知识_第2页
操作系统原理-方敏-进程与线程基本知识_第3页
操作系统原理-方敏-进程与线程基本知识_第4页
操作系统原理-方敏-进程与线程基本知识_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

进程和线程基本知识操作系统课程组内容安排进程的基本概念进程调度进程间的相互作用线程的基本概念2进程的基本概念定义进程是程序的一次执行,该进程可与其它进程并发执行;它是一个动态的实体,在传统的操作系统设计中,进程既是资源的基本分配单元,也是基本的执行单元。进程与程序的区别和联系程序是静态的,进程是动态的。程序是有序代码的集合;进程是程序的一次执行。进程是暂时的,程序的永久的。进程是一个变化的过程,有生命周期,暂时存在,程序没有生命周期,可长久保存。进程还是操作系统资源分配和保护的基本单位,程序没有此功能。进程与程序的对应关系。通过多次执行,一个程序可对应多个进程;通过调用关系,一个进程可包括多个程序。进程与程序的结构不同。3进程的基本概念进程的组成PCB

ProcessControlBlock

灵魂,进程存在的唯一标志。数据程序程序:描述了进程要完成的功能,是进程执行时不可修改的部分。数据:进程执行时用到的数据(用户输入的数据、常量、静态变量)。工作区

工作区:参数传递、系统调用时使用的动态区域(堆栈区)。实体4进程的基本概念进程/线程的执行运行Running被调度时间片用完,中断资源释放或事件完成阻塞Blocked等待资源和事件进程占有处理机,处理机正在执行该进程的程序。进程已获得除处理机外的所需资源,等待分配处理机执行。也叫等待、挂起、睡眠态,此时进程因等待某种条件(如I/O操作或进程同步)无法运行。引起进程阻塞的原因很多,系统将根据不同的阻塞原因将进程插入某个相应的阻塞队列中。就绪Ready5进程的基本概念运行就绪阻塞被调度时间片用完,中断资源释放或事件完成等待资源和事件新建创建完毕结束结束执行五种进程状态转换6进程的基本概念进程的特征并发性:执行时间可以重叠;动态性:有生命周期,存在不同的状态;独立性:独立执行,是资源分配和调度的独立单位;制约性:虽然独立执行,但可能存在相互制约关系;异步性:各进程执行时间相对独立,不确定;结构性:拥有固定结构。7进程调度定义就是按照一定的算法,从就绪队列中选择某个进程占用CPU的方法——对CPU资源进行合理的分配使用,以提高处理机利用率,并使各进程公平得到处理机资源。进程调度算法先来先服务调度算法(FCFS,FirstComeFirstServed)PCBPCBPCBPCB就绪队列CPU8进程调度基于优先数的调度算法(PrioritySchedulingAlgorithm)思想:给每一个进程设置一个优先数(优先级),系统在调度时优先选择具有高优先级的进程占用CPU。具有相同优先数的进程按照FCFS算法执行。优先数的确定:运行前:可根据外设的使用情况,运行时间的长短,紧急程度,重要程度等因素确定。运行中:静态优先数法:进程创建时就规定好它的优先数,这个数值在进程运行时不变。动态优先数法:进程的优先数在执行过程中可以根据情况变化而改变。9进程调度时间片轮转法(RR,RoundRobin)特点:专门为分时系统设计。类似于FCFS算法但是增加了抢占及进程间的切换功能。思想:系统规定一个时间长度(时间片/时间量)作为允许一个进程运行的时间,如果在这段时间该进程没有执行完,则必须让出CPU等待下一次分配的时间片。PCBPCBPCBPCBCPU就绪队列时间片用完执行10进程调度多级反馈队列调度算法(MultilevelFeedbackQueueScheduling)思想:引入多个就绪队列,通过对各队列的区别对待,达到一个综合的调度目标。CPU降低进程优先级完成PCBPCBPCBPCB最高优先级队列PCBPCBPCBPCB次高优先级队列PCBPCBPCBPCB低优先级队列执行时间递增11进程间的相互作用同步进程之间相互合作、协同工作的关系称为进程的同步。简单说来就是:多个相关进程在执行次序上的协调。进程间的直接制约。临界资源也称独占资源,是指在一段时间内只允许一个进程访问的资源。例如打印机,磁带机,也可以是进程共享的数据、变量等。互斥定义:当多个进程因为争夺临界资源而互斥执行称为进程的互斥。进程间的间接制约。12进程间的相互作用互斥解决方案关中断法(开关中断指令)也称为“硬件锁”,是实现互斥最简单的方法。做法:每个进程在进入临界区后先关中断,屏蔽其它请求,在离开之前再开中断。锁变量法(测试和设置指令)做法:设置一个共享(锁)变量W,初值为0。当一个进程想进入其临界区时,它首先测试这把锁。如果锁的值为0,则进程将其置为1并进入临界区。若锁已经为1,则进程等待直到其变成0。于是,0就表示临界区内没有进程,1表示已经有某个进程进入了临界区。其它方法Dekker算法:进程被强制轮流进入临界区(不管是否愿意)。Peterson算法:设置标识指示是否又要求进入临界区。 ……13进程间的相互作用信号量(Semaphore)和P、V操作信号量:1965年由荷兰学者Dijkstra提出,它是一种特殊的数据结构。功能:表示资源的实体。特殊之处:每个信号量与一个队列关联;其值只能通过初始化和P、V操作来访问。 信号量的类型:公用信号量:用于进程间的互斥,初值通常为1私有信号量:用于进程间的同步,初值通常为0或n14进程间的相互作用P、V操作(均是原语)P操作:荷兰语“proberen”——“检测”之意。 意味着请求分配一个单位资源。P(S)://S为信号量{S=S-1;if(S<0){调用进程被阻塞,进入S的等待队列;}}PCBPCBPCBPCB和S相关的等待队列PCB15进程间的相互作用V操作:荷兰语“verhogen”——“增量”之意, 意味着释放一个单位资源。V(S)://S为信号量{S=S+1;if(S<=0){从S的等待队列中唤醒一个进程使其进入就绪状态;}}PCBPCBPCBPCB和S相关的等待队列PCB16进程间的相互作用信号量及P、V操作的应用进程的互斥semaphore

S;//设置公有信号量S=1;//初值{…

P(S);

printfile1;V(S);…}{…

P(S);

printfile2;V(S);…}17进程间的相互作用进程的同步——生产者与消费者问题

问题描述:生产者缓冲区消费者{cooking;

P(S1);putindish;

V(S2);}semaphoreS1,S2

;//设置私有信号量S1=1;//表示盘子是否空S2=0;//表示盘子里是否有东西{P(S2);takeoutfromdish;

V(S1);eating;}18线程的基本概念定义线程(thread)也叫轻型进程,是一个可执行的实体单元。它代替以往的进程,成为现代操作系统中处理机调度的基本单位。线程和进程的关系多线程模型1、线程是进程的一个组成部分,线程由进程创建,因此一个进程中至少存在一个线程,线程还可以创建其它线程。2、进程是资源分配和保护的基本单位,线程只能在进程的地址空间活动,线程只能使用其所在进程的资源。19线程的基本概念线程的结构PCB程序数据进程地址空间TCB栈线程1TCB栈线程2TCB栈线程3线程的特点:1、线程作为基本的调度单位,其状态有:就绪、运行、阻塞等;2、进程中都所有线程共享进程的存储空间和分配资源。工作区20线程的基本概念线程优势创建和撤消线程的开销非常小。不需要向系统请求独立的地址空间及进行相关的地址空间复制(例如父子进程),因此创建和撤销线程系统的开销要远小于进程。切换迅速。线程的上下文环境要比进程简

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论