操作系统作业2 进程和进程通信

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

实验二进程和进程通信

实验报告

(一)实验目的

⏹通过使用进程和进程通信方面的系统调用的,加深理解有关进程方面的基本概念。

通过实验对进程有进一步的感性认识,掌握系统V的IPC机制。

(二)实验题目

⏹1.设计一个程序,创建一个子进程,使父子进程合作,协调地完成某一功能。要

求在该程序中还要使用进程的睡眠、进程图象改换、父进程等待子进程终止、信号的设置与传送(包括信号处理程序)、子进程的终止等有关进程的系统调用。

⏹2.利用UNIX的消息通信机制、共享内存机制(要用信号灯实施进程间的同步和

互斥)实现两个进程间的数据通信。具体的通信数据可从一个文件读出,接收方进程可将收到的数据写入一个新文件,以便能判断数据传送的正确性(对文件操不熟悉的同学可不必通过读写文件,只要键盘输入和输出至屏幕进行比较即可)。(蓝字部分对一般同学不作要求)

(三)实验报告要求

⏹要求在实验室当场调试完成,经老师检查通过,登记,实验报告可免做。

⏹对于因特殊情况,不能到实验室上机的同学,可在自己的Linux机器上机,但要求

写实验报告,包括题目、数据结构的说明,画出程序框图,在源程序中加入注释,说明程序的测试方法和测试结果,以及实验总结或体会。

⏹在实验报告中要有一幅Linux系统运行的截图,截图中要注释实验者的姓名或学号。

实验报告不要做压缩文件。

⏹为了截图,可以建立以学号为用户名的帐号,或在命令行中输入姓名或学号(会显

示出错,没有关系),或在程序加入注释,再对其截图。

⏹至少要完成一道实验题。

一、运行程序

(一)、数据结构说明和程序框图

1、数据结构说明

main()函数:子进程的创建都是在main()函数里面;

signalfun(),是信号SIGUSR1对应的处理函数;

writetofile函数,是对一个文件写如一定的内容的函数;

readfromfile,是从一个文件里面读取内容的函数。

2、程序框图如下:

(二)、源程序

1、父子进程程序

#include

#include

main()

{

int pid,status = 1;

void func();

signal(SIGUSR1,func); /* 预置信号处理程序,将SIGUSR1设置为func函数的功能*/

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

if (pid) { /* 父进程*/

printf("It is the parent process.\n");

printf("Parent: will send signal.\n");

kill(pid,SIGUSR1); /* 发送信号,即发送执行func函数的信息*/ pid = wait(&status); /* 父进程等待子进程终止*/

printf("Child process %d,status=%d \n",pid,status);

}

else { /* 子进程*/

sleep (2); /* 等待接受信号*/

printf("It is the child process.\n");

printf("Child:signal is received.\n");

execvp ("pwd",(char*)0); /* 映像改换,显示当前工作区,exevcp不用给出具体路径,(char*)0指向pwd命令*/

printf("execl error.\n"); /* 映像改换失败*/

exit(2);

}

printf ("Parent process finish. \n");

}

void func ()

{

system("date");

}

2、消息通信机制

/* msgcom.h */

#include

#include

#include

#include

#define MSGKEY 5678

struct msgtype{

long mtype;

int text;

};

#include "msgcom.h"

main()

{ /* 请求进程*/

struct msgtype buf;

int qid,pid;

qid=msgget(MSGKEY,IPC_CREAT|0666); /* MSGKEY为约定的消息队列关键字,访问控制权限为0666 */

buf.mtype=1; /* 请求进程发送消息标识为1 */

buf.text=pid=getpid(); /* 请求进程发送消息内容为进程标识*/

msgsnd(qid,&buf,sizeof(buf.text), IPC_NOWAIT|04000); /* 发送消息正文长度为buf的大小*/

msgrcv(qid,&buf,512,pid,MSG_NOERROR); /* 指定接收mtype=pid的信息,即请求进程发送给服务器处理后的信息*/

printf("Request received a massags from server, type is: %d\n",buf.mtype);

}

#include "msgcom.h"

main()

{ /* 服务器进程*/

struct msgtype buf;

int qid;

if((qid=msgget(MSGKEY,IPC_CREAT|0666))== -1)

return(-1); /* 出错处理*/

相关文档
最新文档