UNIX_Linux操作系统内核结构7章.pdfVIP

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

第七章 进程控制 控制进程上下文的系统调用包括三类: 1、与存储相关的 fork exec brk 2、与同步相关的 exit wait signal kill 3、其他类别 setpgrp setuit 7.1 创建进程fork pid = fork( ) fork算法主要完成以下操作: 1、检查系统资源,为新进程在核心进程表proc表中分配一 个空表项。 2、为子进程分配一个唯一的进程标识数PID,确认用户的总 进程数没有超限。 3、拷贝父进程的上下文到子进程中,包括真正用户标识号 、有效用户标识号、进程组号、调度优先权等。初始化子进 程中的相关参数,如初始优先权数、初始CPU使用时间、计 时域等。调整文件的引用计数等。 4、增加与该进程相关的file表项和活动inode表项的引用计 数。 5、对父进程返回子进程的进程号;对子进程则返回0。 算法fork 输入:无 输出:对父进程是子进程的PID 对子进程是0 { 检查可用的核心资源(如内外存空间、页表等); 取一个空闲的进程表项和唯一的PID号; 检查用户没有过多的运行进程; 将子进程的状态设为“创建”状态; 将父进程的进程表项中的数据拷贝到子进程的进程表项中; 当前目录的索引节点和改变的根目录的引用计数加一; 系统打开文件表中相关表项的引用计数加一; 在内存中作父进程上下文的拷贝(包括u区、正文、数据、堆栈); 算法fork (续) 在子进程的系统级上下文中压入虚设的系统级上下文层 /* 虚设的上下文层中含有使子进程能够识别自己的数据, * 并使子进程被调度时从这里开始 */ if (正在执行的进程是父进程) { 将子进程的状态设置为“就绪”状态; return (子进程的PID); /* 从系统态到用户态*/ } else /* 当前正在执行的进程是子进程 */ { 初始化u区的计时域; return (0); /* 从系统态返回到用户态*/ } } 实例1:双进程文件拷贝 main(int argc, *argv[ ]) { 两个进程共享读指针和写指 fdrd = open(argv[1], O_RDONLY); 针,但运行的结果并不能保证新 fdwt = create(argv[2], 0666); fork( ); 文件中的内容与老文件中的完全 /* 父子进程执行下面相同的代码*/ 相同,这取决于父子两个进程的 rdwrt( ); 调度顺序。 exit(0); —— 多进程环境下的数据一 } 致性问题。 rdwrt( ) { for(; ;)

文档评论(0)

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

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

1亿VIP精品文档

相关文档