西安理工大学《linux操作系统》Linux-第三讲.pptVIP

西安理工大学《linux操作系统》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文档。上传文档
查看更多
进程的创建-fork() 接下来,子进程的状态被设置为TASK_UNINTERRUPTIBLE以保证它不会马上投入运行。 调用get_pid()为新进程获取一个有效的PID。 然后,更新不能从父进程继承的PCB的其他所有域,例如,进程间亲属关系的域。 把新的PCB插入进程链表,以确保进程之间的亲属关系。 把新的PCB插入pidhash哈希表。 把子进程PCB的状态域设置成TASK_RUNNING,并调用wake_up_process( )把子进程插入到运行队列链表。 让父进程和子进程平分剩余的时间片。 返回子进程的PID,这个PID最终由用户态下的父进程读取 进程的组织方式-进程链表 在task_struct中定义如下: task_struct *prev_task, *next_task 宏for_each_task()遍历整个进程链表 #define for_each_task(p) \ for (p = init_task ; (p = p-next_task) != init_task ; ) 进程的组织方式-哈希表 哈希函数 #define pid_hashfn(x) \ ((((x) 8) ^ (x)) (PIDHASH_SZ - 1)) 图为地址法处理冲突时的哈希表 假定哈希表义为: struct task_struct *pidhash[PIDHASH_SZ] 对给定的PID,如何快速找到对应进程? 进程的组织方式-可运行队列 把可运行状态的进程组成一个双向循环链表,也叫可运行队列(runqueue) 在task_struct结构中定义了两个指针。 struct task_struct *next_run, *prev_run; init_task起链表头的作用 在调度程序运行过程中,允许队列中加入新出现的可运行态进程,新出现的可运行态进程插入到队尾 进程的组织方式-等待队列 等待队列表示一组睡眠的进程 可以把等待队列定义为如下结构: struct wait_queue { struct task_struct * task; struct wait_queue * next; }; 如何让正在运行的进程等待某一特定事件? Linux内核中实现了sleep_on()函数,请给出该函数的实现。 如果要让等待的进程唤醒,就调用唤醒函数wake_up(),它让待唤醒的进程进入TASK_RUNNING状态。 线程在Linux中的实现 轻量级进程概念 clone(),fork()与vfork()实现的区别 内核线程 计算机科学与工程学院 第三章 进程 进程介绍 进程描述符与任务结构 进程的组织方式 进程的状态切换 进程的创建 Linux下线程的实现与内核线程 进程的终结 进程描述 进程描述符及任务结构 slab分配task_struct结构 内核把任务放入任务队列的双向循环链表 进程描述符的存放 进程状态 设置当前进程状态 进程上下文 进程家族树 进程 进程的定义 操作系统角度的定义 进程与线程的关系 进程提供的的虚拟机制 Linux下的进程的起止 进程是正在执行的程序代码的活标本 虚拟处理器和虚拟内存 进程介绍-程序和进程 进程介绍-进程层次结构 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

文档评论(0)

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

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

版权声明书
用户编号:8135026137000003

1亿VIP精品文档

相关文档