Linux内核剖析之进程小结教学演示课件.ppt

Linux内核剖析之进程小结教学演示课件.ppt

  1. 1、本文档共14页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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个必要条件成立,如何确定资源的合理分配算法,避免进程永久占据系统资源。此外,也要放在进程在处于等待状态的情况下占用资源,在系统运行过程中,对进程发出的每一个系统能够满足的资源申请进行动态检查,并根据检查结果决定是否分配资源,若分配后系统可能发生死锁,则不予分配,否则予以分配。因此,对资源的分配

文档评论(0)

wuyoujun92 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档