- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
现代操作系统 Chapter 2 Part2.ppt
Contents 2.1 Processes 2.2 Interprocess communication (IPC) 2.3 Classical IPC problems 2.4 Threads 2.5 Scheduling 2.4 Threads 2.4.1 Threads usage 2.4.2 The classical thread model 2.4.3 Implementing threads in user space 2.4.4 Implementing threads in the kernel 2.4.1 Threads usage Why would anyone want to have a kind of process within a process? It turns out there are several reasons for having these miniprocesses, called threads(线程). In many applications, multiple activities are going on at once. By decomposing such an application into multiple sequential threads that run in quasi-parallel (准并行), the programming model becomes simpler. Threads are lighter weight than processes, they are easier to create and destroy than processes. Performance. When there is substantial computing and also substantial I/O, having threads allows these activities to overlap, thus speeding up the application. An example of multithread 2.4.2 The classical thread model The process model is based on two independent concepts: resource grouping and execution. Sometimes it is useful to separate them; this is where threads come in. A process has an address space containing program text and data, as well as other resources. A thread has a program counter, registers, a stack. Process are used to group resources together; threads are the entities scheduled for execution on the CPU. 线程的引入 进程的两个基本属性: ① 进程是一个可拥有资源的独立单位; ② 进程同时又是一个可以独立调度和分配的基本单位。 由于进程是一个资源拥有者,因而在进程的创建、撤消和切换中,系统必须为之付出较大的时空开销。也正因为如此,在系统中所设置的进程数目不宜过多,进程切换的频率也不宜太高,但这也就限制了并发程度的进一步提高。 线程的引入 如何能使多个程序更好地并发执行,同时又尽量减少系统的开销,已成为近年来设计操作系统时所追求的重要目标。 能否将进程的两个基本属性分开,由操作系统分别进行处理。即把处理机调度和其他资源的分配针对不同的活动实体进行,以使之轻装运行;而对拥有资源的基本单位,又不频繁地对之进行切换。 在这种思想的指导下,产生了线程的概念。 线程是进程中的一个实体,是被系统独立调度和分配的基本单位。 线程示意图 线程与进程的比较 下面将从四个方面比较线程和进程: 调度 并发性 拥有资源 系统开销 (1)调度 在引入线程的操作系统中: 线程是调度和分配的基本单位 进程是资源拥有的基本单位 把传统进程的两个属性分开,线程便能轻装运行,从而可显著地提高系统的并发程度。 在同一进程中,线程的切换不会引起进程的切换;在由一个进程中的线程切换到另一个进程中的线程时,才会引起进程的切换。 (2)并发性 在引入线程的操作系统中,不仅进程之间可以并发执行,而且在一个进程中的多个线程之间亦可并发执行,因而使操作系统具有
您可能关注的文档
最近下载
- 超临界再压缩循环演示回路控制gt2013-94512.pdf VIP
- 员工厨房作业免责协议书6篇.docx VIP
- 2025年粮油仓储管理员职业技能竞赛参考试题库(含答案).docx VIP
- 《药物学》课程标准.pdf VIP
- GB/T 29319-2024 光伏发电系统接入配电网技术规定.pdf VIP
- 2025版展会活动保洁托管服务合同范本.docx VIP
- 人教版生物学选择性必修1全册课件.pptx
- 深度解析《GB 19522-2024车辆驾驶人员血液、呼气酒精含量阈值与检验》.pptx
- 输血最新课件(共34张PPT).pptx VIP
- ArchiCAD提取CAD高程点自动生成地形方法.doc VIP
文档评论(0)