




已阅读5页,还剩10页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
2.7线程的概念及其实现,自从20世纪60年代提出进程概念以来,在操作系统中一直都是以进程作为能独立运行的基本单位。直到80年代中期,人们又提出了比进程更小的能独立运行的基本单位线程,用它来提高系统内程序并发执行的速度,减少系统开销,从而可进一步提高系统的吞吐量。近几年,线程概念已得到了广泛应用,不仅在新推出的操作系统中,大多都已引入了线程概念,而且在新推出的数据库管理系统和其它应用软件中,也都纷纷引入了线程来改善系统的性能。,2.7.1线程的引入,如果说,在操作系统中引入进程的目的,是为了使多个程序并发执行,以改善资源利用率及提高系统的吞吐量;那么,在操作系统中再引入线程则是为了减少程序并发执行时所付出的时空开销,使操作系统具有更好的并发性。,然而为使程序能并发执行,系统还必须进行以下的一系列操作。创建进程。系统在创建进程时,必须为之分配其所必需的、除CPU以外的所有资源。如内存空间、I/O设备以及建立相应的PCB。撤消进程。系统在撤消进程时,又必须先对这些资源进行回收操作,然后再撤消PCB。进程切换。在对进程进行切换时,由于要保留当前进程的CPU环境和设置新选中进程的CPU环境,为此须花费许多CPU时间。,2.7.2进程与线程的关系,线程具有许多传统进程所具有的特征,故又称为轻型进程(Light-WeightProcess)或进程元;而把传统的进程称为重型进程(Heavy-WeightProcess),它相当于只有一个线程的任务。在引入了线程的操作系统中,通常一个进程都有若干个线程,至少需要有一个线程。下面,我们从调度、并发性、系统开销、拥有资源等方面,来比较线程与进程。,1.调度,在传统的操作系统中,拥有资源的基本单位和独立调度的基本单位都是进程。而在引入线程的操作系统中,则把线程作为调度和分配的基本单位,而把进程作为拥有资源的基本单位,使传统进程的两个属性分开,线程便能轻装运行,从而可显著地提高系统的并发程度。在同一进程中,线程的切换不会引起进程的切换,在由一个进程中的线程切换到另一个进程中的线程时,将会引起进程的切换。,2.并发性,在引入线程的操作系统中,不仅进程之间可以并发执行,而且在一个进程中的多个线程之间,亦可并发执行,因而使操作系统具有更好的并发性,从而能更有效地使用系统资源和提高系统吞吐量。例如,在一个未引入线程的单CPU操作系统中,若仅设置一个文件服务进程,当它由于某种原因被阻塞时,便没有其它的文件服务进程来提供服务。在引入了线程的操作系统中,可以在一个文件服务进程中,设置多个服务线程,当第一个线程等待时,文件服务进程中的第二个线程可以继续运行;当第二个线程阻塞时,第三个线程可以继续执行,依此类推,从而显著地提高了文件服务的质量以及系统吞吐量。,3.拥有资源,不论是传统的操作系统,还是设有线程的操作系统,进程都是拥有资源的一个独立单位,它可以拥有自己的资源。一般地说,线程自己不拥有系统资源(只有一些必不可少的资源),但它可以访问其隶属进程的资源。亦即,个进程的代码段、数据段以及系统资源,如已打开的文件、I/O设备等,可供同一进程的所有线程共享。,4.系统开销,由于在创建或撤消进程时,系统都要为之分配或回收资源,如内存空间、I/O设备等。因此,操作系统所付出的开销将显著地大于在创建或撤消线程时的开销。类似地,在进行进程切换时,涉及到当前进程整个CPU环境的保存以及新被调度运行的进程的CPU环境的设置。而线程切换只需保存和设置少量寄存器的内容,并不涉及存储器管理方面的操作。可见,进程切换的开销也远大于线程切换的开销。此外,由于同一进程中的多个线程具有相同的地址空间,致使它们之间的同步和通信的实现,也变得比较容易。在有的系统中,线程的切换、同步和通信都无需操作系统内核的干预。,2.7.3线程的状态及转换,线程既然是进程中的一个执行体,是系统进行调度的独立单位,它就是一个动态的过程,因此,也就有生命周期,即由创建而产生,由调度而执行,由撤销而消亡。在线程的生命周期中,它总是从一种状态变迁到另一种状态。与进程类似,在不同的操作系统中,线程的状态有所不同,下面给出在Windows2000/XP中的线程及其转换图,如图2.18。,初始化,备用,终止,就绪,运行,转换,等待,创建和初始化线程对象,重新初始化,放入就绪队列,选择执行,被抢先,抢先或时间片结束,执行完成,描述表切换,等待完成,等待对象句柄,换出内核堆栈,换入内核堆栈,图2.18在Windows2000/XP中的线程及其转换图,2.7.4线程调度,线程调度与进程调度类似,原则上讲,高优先级的线程比低优先级的线程有更多的运行机会,当低优先级的线程在运行时,被唤醒的或结束I/O等待的高优先级线程立即抢占CPU并开始运行,如果线程具有相同的优先级,则通过轮转来抢占CPU资源。在Windows2000/XP中,采用的是基于优先级的抢占式多CPU调度策略。,2.7.5线程通信,为使系统中的多线程能有条不紊地运行,在系统中必须提供用于实现线程间同步和通信的机制。为了支持不同频率的交互操作和不同程度的并行性,在多线程OS中通常提供多种同步机制,如互斥锁、条件变量、计数信号量以及多读、单写锁等。1.互斥锁(mutex)2.条件变量3.信号量机制私用信号量(privatesemaphore)。公用信号量(publicsemaphore)。,2.7.6多线程应用举例,下面以客户/服务器应用模式中服务器程序设计为例,来说明多线程技术的应用。假定该服务器程序只提供两类功能,分别由函数funcl()和func2()来实现。客户在请求服务时要指明功能号1或2。另外限制需要同时提供服务的客户数目。在服务器端为请求服务的每个客户建立一个线程,专门为该客户提供服务。下面是该服务器程序的基本结构:创建邮箱,分配网络通道并连接邮箱;,while(1)同步读取邮箱信息message;switchmessagecase请求连接:if(有空位)建立网络链路通道chan;if(功能号=1)建立新线程,指定funcl(chan)为执行代码*注意:此时该线程并未执行*else建立新线程,指定func2(chan)为执行代码else拒绝服务请求;case断
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 飒美小升初课件
- 2025年中医药临床应用评估考核答案及解析
- 外包方安全管理培训内容课件
- 2025年康复医学病例分析能力检测模拟考试卷答案及解析
- 内科各章节考试题及答案
- 2025年临床病理诊断题库及答案
- 2025年急救医学心肺复苏技能考核测试卷答案及解析
- 高性能石墨块生产线项目投资计划书
- 外出安全培训感触与收获
- 2025年屠宰工厂质检员考试试题及答案
- 2025年吉林省教育系统后备干部考试题及答案
- 2025-2026学年人教版(2024)初中体育与健康七年级全一册教学计划及进度表(第一学期)
- 富士康自动化培训知识课件
- 2025-2026学年济南版(2024)初中生物八年级上册教学计划及进度表
- 2025年中小学生宪法知识竞赛试题及答案
- 制冷复审课件
- “一带一路”倡议下的企业出海战略研究
- 体系管理知识培训课件
- 辽宁沈阳地铁有限公司所属公司招聘笔试题库完整参考答案详解
- 《新媒体营销与运营》-课程标准、授课计划
- 数字媒体技术认知实习
评论
0/150
提交评论