- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
3章進程
操作系统与实验教程 第3章第1讲 第3章 进程 本章主要内容 3.1 进程的基本概念 3.2 进程控制 3.3 进程同步与互斥 3.4 Linux进程 3.1 进程的概念 本节内容要点 多道程序并发执行的特点及所产生的问题 进程的定义 进程与程序的区别 进程映像及其组成,PCB的概念 进程的可能状态及其变迁条件 3.1 进程的概念 现代操作系统最主要的特点:实现多道程序并发执行,并由此引发资源共享。 进程概念引入的目的: 为了对并发执行的程序进行动态描述。 进程是操作系统最核心的概念,操作系统对于资源的分配和管理都是围绕进程进行的。 3.1.1 多道程序并发执行 1.程序的顺序执行 一个程序由若干个程序段组成,而这些程序段必须按照一定的先后顺序执行,称为程序的顺序执行。如下图所示,两个作业之间的运行方式就是单道顺序执行的方式: 程序顺序执行的特点: 顺序性 封闭性 可再现性 程序单道顺序执行之所以具有以上特点,是因为单道环境下作业独占系统资源。 2.程序的并发执行以及“与时间有关的错误” 2.程序的并发执行以及“与时间有关的错误” 程序的并发执行: 如下图P1、P2两个程序,阴影部分所表示的时间就是它们并发执行的时间。 程序并发执行产生的与时间有关的错误: [例3-1]读写缓冲区操作 [例3-2]假设某飞机定票系统在t0时刻有A、B、C、D四个终端程序同时都要对机票库中的某航班当前剩余票数X进行操作。如果每个终端程序的当前定票需求为N,并对共享变量X进行如下操作: 在机票数据库中取出当前剩余票数X;(第1步) 判断X0(有票吗)? (第2步) 如果有, X≥N(票够吗)?(第3步) 如果够,则出票(打印票据);(第4步) X=X-N(修改剩余票数);(第5步) 将X回写到数据库中;(第6步) 初始条件:设系统剩余票数为10,终端A、B需要的票数也均为10。 首先,终端程序A抢先执行,当执行完第3步,正在打印票据; 此时,系统调度到终端程序B的请求执行。 最终结果?? 导致“与时间有关的错误”的原因: 与诸程序的执行速度有关; 由于多个程序都共享了同一个变量或者互相需要协调同步; 对于变量的共享或者互相协作的过程没有进行有效地控制。 在例3-2中,如果诸终端程序是按照下述方式执行,则可以避免发生“与时间有关的错误”: 如果A能够执行得快一点,或者时间片长一点,使它来得及将X的剩余值回写到数据库中;或者A再慢一点,使票没有出。皆不会出现“与时间有关的错误”。(与诸程序的执行速度有关) 如果诸终端程序并发执行时操作的是不同的变量而不是共享变量,也不会出现“与时间有关的错误”。 (共享了同一个变量) 如果能够对该共享变量X在其共享过程中加以控制,实现当一个程序还没有使用完时另一个程序就不能使用,那么也可以避免“与时间有关的错误”。(没有进行有效地控制) 上述3种避免发生“与时间有关的错误”的方法中,操作系统无法使用前两种,因为: 第1种办法不可行是因为并发程序执行时所具有的不确定性是操作系统的特征,操作系统无法控制每个程序所需要的执行速度; 第2种办法不可行在于共享是操作系统的特点,是其提高资源利用率的宗旨所在。 因此,操作系统只能针对第3种解决方法,在资源分配和使用的过程中通过采取有效的措施来避免发生“与时间有关的错误”,保证程序并发执行结果的正确性。 3.程序并发执行的特点 (1)????? 失去了程序的封闭性和可再现性 由于程序相互协作打破了程序的封闭性及可再现性(如例3-1中两程序操作单独缓冲区); 由于资源共享打破了程序的封闭性及可再现性(如例3-2中的公共变量X,系统剩下的机票数)。 3.程序并发执行的特点 (2)????? 程序与任务不再一一对应 程序并发执行时,多个任务可以共存于一个程序之中,从而使得一个程序对应于多个任务。比如,多个终端用户都对服务器提出某个相同的服务请求,服务器则需要针对每个用户创建一个任务去分别完成,这些针对不同用户的不同任务执行的却是相同的服务程序;另外,一个任务中也可能涉及多个程序调用或转移,从而打破了一对一的关系。 3.程序并发执行的特点 (3)?程序并发执行中存在相互制约的关系 间接制约:因多道并发而导致的对于资源的竞争和共享引起的。(例3-2) 直接制约:多道并发的程序相互协作共同完成某个任务引起的。(例3-1) 结论: 多道程序由于并发执行和共享资源,打破了单道程序由于独占资源所具有的执行过程的封闭性,并发程序在并发执行过程中相互之间会有干扰或制约,而这些干扰和制约的不可预知性和随机性给操作系统实现多道程序并
您可能关注的文档
最近下载
- 电路电流练习.doc VIP
- 安全生产标准重大危险源管理人员培训记录.docx VIP
- 商业写字楼智能化初步设计在2025年的智能化物业管理系统评估报告.docx
- DB32_T 4342-2022工业企业全过程环境管理指南.docx VIP
- 传感器数字式传感器详解.ppt VIP
- 马工程外国文学史第一章古代文学.pptx VIP
- 低空经济行业市场前景及投资研究报告:Joby,Archer,国内eVTOL产业.pdf VIP
- 《数据可视化技术》课件.ppt VIP
- Unit 1 Helping at home 第5课时 Part B Let’s learn&Listen and chant(教学设计)英语人教PEP版四年级上册.pdf
- 《普通遗传学》第9章近亲繁殖和杂种优势.ppt
文档评论(0)