- 1、本文档共14页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Linux内核剖析之进程小结教学演示课件
Linux内核分析之进程总结 姓名:********* 班级:四 班 学号:*************** 1.1.1 进程的概念 在Linux系统中,进程被赋予了下述特性的含义和特性: 一个进程是对一个程序的执行。 一个进程的存在意味着存在一个task_struct结构,它包含着相应的进程控制信息。 一个进程可以生成或消灭其子进程。 一个进程是获得和释放各种系统资源的基本单位。 1.2 进程的虚拟地址结构 1.2.1 管理每个进程中的区 系统设立了称为vm_area_struct的数据类型,进程的每个区都对应一个vm_area_struct结构,它主要包括下列内容: 区的标志位,指明该区的类型以及是否被锁住,是否可共享等属性。缺页处理程序会根据地址所在区的标志位查找缺页原因,并做相应处理。 区的起始地址,结束地址。 共享区域指针,给出共享区 vm_area_struct链表。 文件系统指针,指向外存中与该区对应的数据文件。 此区域的操作函数指针。 1.3进程的状态和状态转换 1.3.1 Linux中的五种状态。 TASK_RUNNING 进程处在执行或就绪状态,表示在占有CPU,或者在就绪队列中等待调度,只要调度到它,就可以投入执行。 TASK_INTERRUPTIBLE 进程正在睡眠,但是可以被软中断信号唤醒。 TASK_UNINTERRUPTIBLE 进程正在睡眠,且不可以被软中断信号唤醒。 TASK_STOPPED 表示进程的执行被暂停,当一个进程受到SIGSTIOP、SIGTSTP、SIGTTIN、SIGTTOU软中断信号后进入这个状态。 TASK_ZOMBIE 进程执行了系统调用exit后,进入僵死状态。 1.4 进程控制 1.4.1 理解Linux系统进程的并发性 下面介绍一下fork的功能与实现过程。 系统调用fork通过执行核心程序fork过程完成的功能是: 为子进程分配一个进程描述符task_struct结构,将父进程的进程描述符的内容复制到新创建的结构中,并重新设置那些与父进程不同的数据成员。 为子进程分配一个唯一的进程标识符号pid 将父进程的地址空间的逻辑副本复制到子进程。 复制父进程相联的有关文件系统的数据结构和用户文件描述符表,这样子进程就继承 了父进程的文件系统相关的信息。 复制软中断信号有关的数据结构。 设备子进程的状态为TASK_RUNNING,把它加入到就绪队列,并启动调度程序。 对父进程返回子进程的进程标识号,对子进程返回零。 1.5 进程管理 Linux是一个多用户多工的操作系统。多用户是指多个用户可以在同一时间使用电脑系统;多工是指Linux可以同时执行多个任务,它可以在还未执行完一个任务时又执行另一项任务。 Linux系统上所有运行的任务都可以称之为一个进程,每个用户任务、每个系统管理守护进程,也都可以称之为进程。Linux用分时管理方法使所有的任务共同分享系统资源。我们所关心的是如何去控制这些进程,让它们能够很好地为用户服务。 Linux系统中所有进程都是相互联系的。除了初始化进程外,所有进程都有一个父进程。新进程不是被创建,而是被复制,或者从以前的进程复制而来。 1.6 进程调度 1.6.1 进程调度涉及的主要问题 调度的时机。 调度标志设置。 调度策略与优先数的计算。 调度的实现。 1.7 进程通信 Linux中的进程通信分为三个部分:低级通信、管理通信和进程通信IPC(inter-process communication)。Linux同时支持计算机间通信(网络通信)用TCP/TP协议并提供了相应的系统调用接口。 1.8 死锁 1.8.1 产生死锁的条件 1、互斥条件:一个资源每次只能被一个进程使用。 2、请求与保持条件:一个进程因请求资源而阻塞时,对已经获得的资源保持不放。 3、不剥夺条件:进程已获得的资源,在未使用完之前,不能强行剥夺。 4、 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。 1.8.2 死锁的解决和预防方法 理解了死锁的原因,尤其是产生死锁的4个必要条件,就可以最大可能地避免、预防和解除死锁。所以,在系统设计、进程调度等方面注意如何不让这4个必要条件成立,如何确定资源的合理分配算法,避免进程永久占据系统资源。此外,也要放在进程在处于等待状态的情况下占用资源,在系统运行过程中,对进程发出的每一个系统能够满足的资源申请进行动态检查,并根据检查结果决定是否分配资源,若分配后系统可能发生死锁,则不予分配,否则予以分配。因此,对资源的分配
您可能关注的文档
- -专题班会游戏之快乐总动员.ppt
- ABC小企业文化诊断汇报.ppt
- (超简易)word文档海报制作教程(技术版).ppt
- ABAQUS热剖析专题.ppt
- ADD_形成团队结构_创建骨架系统.ppt
- ACM程序设计–计算简单题.ppt
- -专题班会正视自己改变自己.ppt
- Access应用技术教程库第四章Access数据表的操作.pptx
- ABBSymphony培训教材–DEH概述.pptx
- AD–用户配置文件.ppt
- Unit 9 I go there by bus 单词讲解课件 湘少版2024英语三年级下册.pptx
- Unit 10 Is she a driver 单词讲解课件 湘少版2024英语三年级下册.pptx
- Unit 8 Once upon a Time 单元检测 人教版七年级英语下册.docx
- Unit 8 Once upon a Time 第1课时 Section A(1a-Pronunciation)(分层作业) 人教版七年级英语下册.docx
- Unit 8 Once upon a Time 第2课时 Section A(2a-2e)(分层作业) 人教版七年级英语下册.docx
- Unit 7 Wash your hands 单词讲解课件 湘少版2024英语三年级下册.pptx
- Unit 8 Children’s Day 单词讲解课件 湘少版2024英语三年级下册.pptx
- Unit 8 Colours单词导学课件 译林版2024英语三年级下册.pptx
- Unit 7 A Day to Remember 第2课时 Section A(2a-2e)(分层作业) 人教版七年级英语下册.docx
- Unit 7 A Day to Remember 第4课时 Section B(1a-1d)(分层作业) 人教版七年级英语下册.docx
文档评论(0)