操作系统原理第一次实验

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

实验一进程管理、管道通信

一.实验名称:

进程管理、管道通信

二.实验目的:

1、熟悉linux下利用gcc、gdb编译、调试C程序

2、掌握进程的概念,明确进程的含义

3、认识并了解并发执行的实质

4、掌握进程间无名管道的通信

三.实验准备:

1、预习linux下利用gcc编译c程序。

2、参考课件及资料掌握进程的创建过程。

3、参考课件及资料掌握进程的并发执行。

4、参考课件及资料掌握进程间无名管道的通信。

四.实验内容:

内容一:敲通如下程序,分析运行结果。

#include

main()

{

int i;

while((i=fork())==-1); //创建一个子进程,直到创建成功为止

printf("i=%d",i);

if(i)printf("It is a parent process!");

else printf("It is a child process!");

}

分析:多次的运行结果不同,执行一次程序,i的值就依次增加,每次增加2,但后面的字符串不变。

执行while((x=fork())==-1);后,父进程创建一子进程,子进程复制了父进程的资源,成为独立于父进程的一个进程,并且子进程的fork()返回值为0,父进程的fork()返回值为刚创建的子进程号。系统先运行子进程,输出It is a parent process!,进入该分支后,因出现IO中断,子进程释放CPU,进入阻塞状态,处于就绪状态的父进程得到CPU继续执行,进入else分支,输出It is a child process!。

图一

内容二:编写程序,用系统调用fork()创建两子进程。父进程显示50次字符串“father”,子进程1显示50次字符串“son”,子进程2显示50次字符串“daughter”。观察并记录屏幕上显示结果,分析原因。(提示:可在各进程中加入sleep,观察结果分析原因)

#include

main()

{

int i,p1,p2;

while((p1=fork())==-1); //创建一个子进程p1

if(p1==0)

for(i=0;i<10;i++)

{

printf("son%d\n",i);

}else{

while((p2=fork())==-1); //创建一个子进程p2

if(p2==0)

for(i=0;i<10;i++)

{

printf("daughter%d\n",i);

}else

for(i=0;i<10;i++)

printf("father%d\n",i);

}

}

分析:首先执行父程序,如果数值小于10,则输出father;执行10次后,进入第一个子程序,i从0开始,输出10次son;接着进入第二个子程序,依次输出10次daughter。

图二

内容三:敲通如下程序,写出运行结果,分析程序功能。

#include

#include

void *ptest(void *arg)

{

printf(" This is the new thread!" );

return(NULL);

}

main()

{

pthread_t tid;

printf(" This is the parent process !" );

pthread_create(&tid,NULL,ptest,NULL);

sleep(1);

return;

}

分析:进入主程序时输出“This is the parent process !”,用创建线程的函数,该函数中主席了指针ptest指向的函数,而后输出“This is the new thread!”返回值为空,程序休眠后结束程序。

图三

内容四:敲通管道通信(课件)例题,写出运行结果,分析程序功能

#include

#include

void main()

{

int x,fd[2];

char buf[30],s[30];

pipe(fd);

while((x=fork())==-1);

if(x==0)

{

sprintf(buf,"This is an example\n");

write(fd[1],buf,30);

exit(0);

}

else

{

wait(0);

read(fd[0],s,30);

printf("%s",s);

}

}

分析:创建管道fd,创建进程,进程标识符为x。如果调用子进程则向缓冲区里写入字符串“This is an example”,然后从buf里向pipe里写入30个字符然后退出子进程,而后调用父进程从该缓冲区里读出30个字符并且显示出来。如果先调用父进程则父进程会被要求等待,从pipe里读出的内容为空,直到调用子进程完成整个写入输出的过程。

图四

内容五:编写一程序,建立一个管道。同时,父进程生产子进程P1,P2,这两个子进程分别向管道中写入各自的字符串,父进程分别读出它们,并显示出来。

#include

#include

main()

{

int p1,p2,fd[2],i=0;

char s1[50],s2[50];

pipe(fd); //父进程建立管道

while((p1=fork())==-1); //创建子进程p1,失败时循环

if(p1==0) //由子进程p1返回,执行子进程p1

for(i=0;i<3;i++)

{

sprintf(s1,"I am child1\n");

write(fd[1],s1,50); //把s1中的50个字符写入管道

相关文档
最新文档