西北工业大学操作系统实验
实验报告实验名称:五构造进程家族树六理解进程的独立空间日期:2013.5班级:10011007学号:2010302554姓名:王振一、实验目的1. 构造进程家族树通过创建若干个子进程,构造进程家族树,分析进程家族树的结构关系;学习相关系统调用(例 如,getpid ()和getppid ()等)的使用方法。2. 理解进程的独立空间理解进程是操作系统独立分配资源的单位,进程拥有自己相对独立的程序空间。二、实验内容1. 构造进程家族树学习进程构造的相关知识,学习获取进程相关信息的系统调用函数。2. 理解进程的独立空间预习进程创建和构造的相关知识,了解C语言程序编写的相关知识。三、项目要求及分析1. 构造进程家族树进程的创建。编制一段程序,使用系统调用fork()创建三个子进程,在各个子进程中再使用系统调用fork()进一步创建子进程,如此重复,构造一棵具有图1形状的进程家族树。分别使用系统调 用getpid ()和getppid ()获取当前进程和父进程的进程标识号并输出。2. 理解进程的独立空间a编写一个程序,在其main ()函数中定义一个变量shared,对其进行循环加/减操作,并输出每 次操作后的结果;b.使用系统调用fork ()创建子进程,观察该变量的变化;c修改程序把shared变量定义到main ()函数之外,重复第(2)步操作,观察该变量的变化。四、具体实现1.流程图a.构造进程家族树2.添加函数的代码a.构造进程家族树else/pidlbpidlb=fork();while(-l=pidlb) pidlb=fork();if(O=pidlb)printf("process lbnt pid%d ppid=%<in" ,getpid()pgetppidO);else/pid2pid2=fork(); while(-l=-pid2)pid2=fork();if(0=pid2)printf( 'process 2nt pid=%d ppid=%dn",getpid(),getppid();Iseprintf(Hprocess 2nt pid=%d ppid=%dn"Pgetpid(),getppid();Ise/pid3pid3=fork();while(-lpid3)pid3=fork():if(0=pid3)printf ("process 3nt pid=%cl ppid=%dnr, ,getpid ()Rgetppid();else/par entprintf("new is :parentn"):return 0;b.理解进程的独立空间int shared=0;int count=0;int pid=fork();while(-l=pid)pid=fork<);if(0=pid)printf ( 'child : nr,);for(count=0;count<7;count+)printf("t%dn"s shared+);elseprintf( parent :n");for(count=0 ; count<7' count+)printf (, shared-i-+);return 0;五、调试运行结果1实验5:admi nCPIucalhot T$./nirpro5bprocess1pid=27247ppid=2724Bprocess1 ap i.d=27248ppid=27247I processlbpid=27249pp 1(1=27247process2pid=2725<)Ppid=2724Bprocesspid=2725ppid=2724E5now i 呂:pareinadni nCP ca ht)£ 丨'J12.实验6:六、实验总结