- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验三进程的创建实验
实验目的
1、 掌握进程的概念,明确进程的含义
2、 认识并了解并发执行的实质
实验内容
1、 编写一段程序,使用系统调用fork()创建两个了进程。当此程序运行时,在系统中 冇一个父进程和两个了进程活动。让每一个进程在屏幕上显示一个字符:父进程显示X, 了 进程分别显示字符b和字符C。试观察记录屏幕上的显示结果,并分析原因。
2、 修改上述程序,每一个进程循环显示一句话。了进程显示?daughter…T^son ......\ 父进程显示parent……\观察结果,分析原因。
实验准备
阅读LINUX的fork.c源码文件(见附录二),分析进程的创建过程。
阅读LINUX的sched.c源码文件(见附录三),加深对进程管理概念的认识。
实验指导
一、进程
UNIX中,进程既是一个独立拥有资源的基木单位,又是一个独立调度的基木单位。一 个进程实体由若干个区(段)组成,包括程序区、数据区、栈区、共享存储区等。每个区又 分为若干页,每个进程配置冇唯一的进程控制块PCB,川于控制和管理进程。
PCB的数据结构如下:
1 进程表项(Process Table Entry)0包括一些最帘用的核心数据:
进程标识符PID、用户标识符U1D、进程状态、事件描述符、进程和U区在内存或外 存的地址、软中断信号、计时域、进程的大小、偏置值nice.指向就绪队列屮下一个PCB 的指针P_Link、指向U区进程正文、数据及栈在内存区域的指针。
2、 U区(UArea)o用于存放进程表项的一些扩充信息。
每一个进程都冇一个私用的U区,其中含冇:进程表项指针、真止用户标识符u-ruid(read user 1D)^有效用户标识符u-euid(elfective user ID)^用户文件描述符表、计时器、内部 I/O参数、限制字段、差错字段、返回值、信号处理数组。
由于UNIX系统采川段页式存储管理,为了把段的起始虚地址变换为段在系统中的物理 地址,便于实现区的共享,所以还冇:
3、 系统区表项。以存放各个段在物理存储器中的位置等信息。
系统把一个进程的虚地址空间划分为若干个连续的逻辑区,有正文区、数据区、栈区等。 这些区是可被共亨和保护的独立实体,多个进程可共亨一个区。为了对区进行管理,核心屮 设迸一个系统区表,各表项中记录了以卜有关描述活动区的信息:
区的类型和大小、区的状态、区在物理存储器中的位置、引用计数、指向文件索引结点的指针。
4、进程区表
系统为每个进程配置了一张进程区表。表屮,每一项记录一个区的起始虚地址及指向系 统区表中对应的区表项。核心通过杳找进程区表和系统区表,便可将区的逻辑地址变换为物 理地址。
二、 进程映像UNIX系统中,组成:
二、 进程映像
UNIX系统中,
组成:
1、 用户级上、
2、 寄存器上、
存器等;
3、 系统级上、
进程是进程映像的执行过程,也就是止在执行的进程实体。它由三部分
F文。主耍成分是用户程序;
F文。由cpu中的一些寄存器的内容组成,女II pc, psw, sp及通用寄
卜?文。包K-os为管理进程所用的信息,有静态和动态之分。
三、 所涉及的系统调用
1、fork()
创建一个新进程。
系统调用格式:
pid=fork()
参数定义:
int fork()
fork()返回值意义如下:
0:在了进程中,pid变量保存的fork()返回值为0,表示当前进程是了进程。
0:在父进程中,pid变量保存的fork()返回值为了进程的id值(进程唯一标识符)。
?1:创建失败。
如果fork()调用成功,它向父进程返回子进程的PID,并向子进程返回0, BP fork()被 调川了一?次,但返回了两次。此时OS在内存中建立一个新进程,所建的新进程是调用fork() 父进程(parent process)的副本,称为子进程(child process)o子进程继承了父进程的许多 特性,并具有与父进程完全相同的用户级上下文。父进程与了进程并发执行。
核心为fork()完成以下操作:
为新进程分配一进程表项和进程标识符
进入fork()后,核心检查系统是否冇足够的资源來建立一个新进程。若资源不足,则 fork()系统调用失败;否则,核心为新进程分配一进程表项和唯一的进程标识符。
检查同时运行的进程数FI
超过预先规定的最大数冃时,fork()系统调用火败。
拷贝进程表项中的数据
将父进程的当前目录和所有己打开的数据拷贝到子进程表项屮,并證进程的状态为“创 建”状态。
子进程继承父进程的所有文件
对父进程当前目录和所有己打开的文件表项屮的引用计数加lo
为了进程创建进程上、下文
进程创建结束,设了?进程状态为“内存中就绪”并返回了进程的标识符。
了进程执行
虽然父进程与了进程程序完全相
您可能关注的文档
最近下载
- 毛泽 东思想概述选择题.doc VIP
- 【中考真题】2024年吉林省中考物理试卷(附答案).doc VIP
- 第一单元劳动创造美好生活1《教室的环境我整理》教案设计人民版初中劳动技术七年级上册.docx
- 11智能制造、工业智能、实验室建设方案.pdf VIP
- 2025年京山市重点人才“蓄水池”专项招聘22人笔试模拟试题及答案解析.docx VIP
- 2025年中国转盘油压机市场调查研究报告.docx
- 2023年05月湖北省京山“蓄水池”专项招考重点人才笔试题库含答案解析.pdf VIP
- CSC-280系列数字式保护(测控)装置说明书 (0SF.451.069)_V4.03.pdf VIP
- 一起学习新队章.pptx
- 小学道德与法治新部编版二年级上册全册教案(2025秋) .pdf
文档评论(0)