第三章 进程 《Linux操作系统原理和 与应用》电子教案.pptVIP

第三章 进程 《Linux操作系统原理和 与应用》电子教案.ppt

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第三章 进程 《Linux操作系统原理和 与应用》电子教案.ppt

第三章 进程 进程的创建 与进程相关的系统调用及其应用 与调度相关的系统调用及应用 进程介绍-程序和进程 进程介绍-进程层次结构 init A B C D E 进程介绍-进程状态    运行态 阻塞态 就绪态 进程介绍-进程示例 #include sys/types.h /* 提供类型pid_t的定义,在PC机上与int型 相同 */ #include unistd.h /* 提供系统调用的定义 */ main() { pid_t pid; /*此时仅有一个进程*/ printf(“PID before fork():%d\n”,(int)getpid()); pid=fork(); /*此时已经有两个进程在同时运行*/ if(pid0) printf(error in fork!); else if(pid==0) printf(I am the child process, my process ID is %d\n,getpid()); else printf(I am the parent process, my process ID is %d\n,getpid()); } 进程控制块-信息分类 状态信息-描述进程动态的变化。 链接信息-描述进程的父/子关系。 各种标识符-用简单数字对进程进行标识。 进程间通信信息-描述多个进程在同一任务上协作工作。 时间和定时器信息-描述进程在生存周期内使用CPU时间的统计、计费等信息。 调度信息-描述进程优先级、调度策略等信息。 文件系统信息-对进程使用文件情况进行记录。 虚拟内存信息-描述每个进程拥有的地址空间。 处理器环境信息-描述进程的执行环境(处理器的寄存器及堆栈等) 进程控制块-Linux进程状态及转换 fork() 进程控制块-进程标识符 每个进程都有一个唯一的标识符,内核通过这个标识符来识别不同的进程 。 进程标识符PID也是内核提供给用户程序的接口,用户程序通过PID对进程发号施令 。 PID是32位的无符号整数,它被顺序编号 每个进程都属于某个用户组。 task_struct结构中定义有用户标识符UID(User Identifier)和组标识符GID(Group Identifier) 这两种标识符用于系统的安全控制 系统通过这两种标识符控制进程对系统中文件和设备的访问。 进程控制块-进程之间的亲属关系 父进程 兄进程 进程P 弟进程 指向父进程 指向兄进程 指向子进程 指向弟进程 进程控制块-部分内容的描述 上面通过对进程状态、标识符及亲属关系的描述,我们可以把这些域描述如下: task_struct{ long state; /*进程状态*/ int pid,uid,gid; /*一些标识符*/ struct task_struct *parent, *child, *o_sibling, *y_sibling /*一些亲属关系*/ … } 进程控制块-如何存放 C语言使用下列的联合结构表示这样一个混合结构: union task_union { struct task_struct task; unsigned long stack[2408]; }; Linux调用alloc_task_struct()函数分配8KB的task_union 内存区,调用free_task_struct()函数释放它 进程控制块-如何存放 C语言使用下列的联合结构表示这样一个混合结构: union task_union { struct task_struct task; unsigned long stack[2408]; }; Linux调用alloc_task_struct()函数分配8KB的task_union 内存区,调用free_task_struct()函数释放它 进程控制块-如何存放 把PCB与内核栈放在一起具有以下好处: (1) 内核可以方便而快速地找到PCB,用伪代码描述如下: p = (struct task_struct *) STACK_POINTER 0xffffe000 (2) 避免在创建进程时动态分配额外的内存 在Linux中,为了表示当前正在运行的进程,定义了一个current宏,可以把它看作全局变量来用,例如curr

您可能关注的文档

文档评论(0)

yuzongxu123 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档