操作系统实验一实验报告.docx_第1页
操作系统实验一实验报告.docx_第2页
操作系统实验一实验报告.docx_第3页
操作系统实验一实验报告.docx_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

操作系统实验一实验报告基本信息l 1.1 实验题目 进程控制实验 1.2完成人 王召德l 1.3报告日期 2015-4-8 实验内容简要描述 2.1实验目标 l 加深对于进程并发执行概念的理解。实践并发进程的创建和控制方法。观察和体验进程的动态特性。进一步理解进程生命期期间创建、变换、撤销状态变换的过程。掌握进程控制的方法,了解父子进程间的控制和协作关系。练习 Linux 系统中进程创建与控制有关的系统调用的编程和调试技术。2.2实验要求 l参考以上示例程序中建立并发进程的方法,编写一个多进程并发执行程序。父进 程首先创建一个执行ls命令的子进程然后再创建一个执行ps命令的子进程,并控制 ps 命令总在 ls 命令之前执行。2.3实验的软硬件环境Ubuntu14.04 intelPC报告的主要内容 l 3.1实验的思路 按照上面的实例,先生成一个子进程让其等待,然后生成第二个子进程,父进程等待其执行ps命令后唤醒第一个子进程执行ls即可。l 3.2实验模型的描述 无l 3.3主要数据结构的分析说明 l无 3.4主要算法代码的分析说明 无l 3.5项目管理文件的说明 无实验过程和结果 l 4.1实验投入的实际学时数 1学时l 4.2调试排错过程的记录 曾尝试让第二个子进程激活第一个子进程,结果发现当运行 ps后,后面的代码将不再执行,所以不可行。l 4.3多种方式测试结果的记录实验结果: l 父进程启动. 12239ls子进程启动. 12240ps子进程启动. 12241 PID TTY TIME CMD12239 pts/27 00:00:00 born12240 pts/27 00:00:00 born12241 pts/27 00:00:00 psps子进程结束.12241唤醒ls子进程.12240键盘中断信号产生.ls子进程被唤醒. 12240. born born.c hello.c pctl pctl.c pctl.o. born.c helelo.h hello.c pctl.c pctl.hls子进程结束.12240父进程结束.122394.4实验结果的分析综合无实验的总结 父进程可以通过fork()函数生成子进程,子进程会从fork()函数开始执行原来的代码,当子进程打开一个其他进程时,新进程便会代替此子进程,子进程后面的代码不会被执行。 进程的概念就是运行起来的程序,在实验中可以看出,同一段代码也可以变成几个不同的进程,但是归根结底他们也都是这一个程序运行得到的。进程并发其实就是分时的占用cpu得到执行。 子进程执行execve()函数可以执行新程序,新程序的进程号不变,替代原来的子进程运行,原来的子进程execve()函数后的代码便不再执行。 信号的产生就是一个中断,中断使cpu停止当前状态而去处理这个中断。可以通过给特定进程发送信号,使其从挂起状态重新启动,以达到控制目的。附录程序源代码#include #include #include #include #include #include typedef void (*sighandler_t) (int);void sigcat()printf(键盘中断信号产生.n);int main(int argc, char *argv) signal(SIGINT,(sighandler_t)sigcat); /注册一个本进程处理键盘中断的函数 int status_1,status_2; char *args_1 = /bin/ls,-a,NULL; char *args_2 = /bin/ps,-a,NULL; int pid_1=fork() ; /建立子进程 if(pid_10) / 建立子进程1失败? printf(Create 1th Process fail!n); exit(0); if(pid_1 = 0) / 子进程1执行代码段 printf(ls子进程启动. %dn,getpid(); pause(); /暂停,等待键盘中断信号唤醒 printf(ls子进程被唤醒. %dn,getpid(); status_1 = execve(args_10,args_1,NULL); exit(0); else printf(n父进程启动. %dn,getpid(); /报告父进程进程号 int pid_2 = fork(); waitpid(pid_2,&status_2,0); /等待ps子进程结束 if(status_2=0) printf(ps子进程结束.%dn,pid_2); printf(唤醒ls子进程.%dn,pid_1); kill(pid_1,SIGINT); waitpid(pid_1,&status_1,0); /等待ps子进程结束 printf(ls子进程结束.%dn,pid_1); printf(父进程结束.%dn,getpid(); exit(0); if(pid_20) / 建立子进程2失败? printf(Create 2th Process fail!n); ex

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论