进程通信实验_第1页
进程通信实验_第2页
进程通信实验_第3页
进程通信实验_第4页
进程通信实验_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

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

文档简介

1、大作业二 进程通信姓名学号:班级:日期:2015年7月1 需求说明(1) 掌握进程间通讯的编程方法; (2) 加深对进程并发执行的理解; (3) 学习利用消息队列和共享存储区实现进程通信的方法。 2 设计说明(1)接收键盘输入进程      负责接收用户的键盘输入,并以适当的方式将由键盘获得的数据交给其它进程处理。 (2)显示进程      负责全部数据显示任务,包括键盘输入数据的显示和提示信息的显示。&#

2、160;(3)分发数据进程      将键盘输入的数据分为3类,即字母、数字和其它,并分别将字母写入文件letter.txt中,数字写入文件number.txt中,除字母和数字外其它数据丢弃。 2.1 结构设计1、 程序能以适当的方式提示用户输入数据;  2、 提示用户有数据被丢弃;  3、 全部的显示任务必须由显示进程完成;  4、 整个程序能够连续处理多组输入数据,直到用户输入“quit”字符串,整个程序结束;  5、 进一步要求:

3、同时采用共享存储区和消息2种方法实现进程之间的通信,并比较这2种通信方法的利弊。2.2 功能设计1、 利用fork()函数创建2个子进程,用一个父进程和两个子进程完成上面的三个实验 任务,用子进程1实现分发数据任务,子进程2实现接受键盘输入任务,父进程实现全部的显示任务。  2、 同时通过共享存储区和消息队列两种进程通讯方式实现上面三个进程之间的同步和互斥。  3、 利用while()循环、kill()函数和signal()函数实现连续多组数据输入。3 测试和使用说明比较消息队列和共享存储区在消息通信机制中的数据传输的时间和性能: 由

4、于两种机制实现的机理和用处都不一样,难以直接进行时间上的比较。如果比较其性能,应更加全面地分析。3.1 使用说明2、有关字符数组初始化函数的使用: 在本实验中频繁使用了memset()函数,且第二个参数均为0,是为了将每次从键盘输入的字符串都能存到一个空的字符数组中,以防止字符的重复和覆盖。 3、在本程序中,需要合理安排父进程和2个子进程的任务,由父进程来负责显示任务是最合理和最简单的情况,因为父进程与子进程在某些方面是共享的,无需另外启用消息通信机制。而且在实现多组数据的输入、显示和分发方面能实现很好的同步和互斥。 4、注意消息缓冲区的数据结构,主要用来存放需要

5、发送或者接收的消息类型和消息正文,在/usr/src/linux-2.4/include/linux/msg.h中描述如下: /*message buffer for msgsnd and msgrcv calls*/ struct msgbuf     long mtype; /消息类型,由用户决定      char mtextMAXMSG;/消息正文 5、在程序

6、修改之前存在一个bug,就是在输入的字符串中不能存在空格或制表符,如果出现空格或者制表符,将只会显示空格或者制表符后面的内容,前面的不显示。这是由于scanf()函数的作用,当他遇到空格或制表符时,就会只读入后面的内容。有人想到会用gets()来接受一行,但是懂C的人基本上都知道gets()是一个很危险的函数,而且很难控制,特别是与scanf()交替使用时前者的劣势更是一览无余,所以gets()一般是不推荐用的。那么我们可以用%n%*c控制语句来隔离掉其中的空格或者制表符对读入一行字符串的影响。3.2 测试说明4 程序清单/*进程通信之消息队列与共享存储区*/ #include<

7、;stdio.h> #include<stdlib.h> #include<string.h> #include<unistd.h> #include<sys/types.h> #include<sys/stat.h> #include<sys/wait.h> #include<linux/ipc.h> #include<linux/msg.h> #include<linux/shm.h>&#

8、160;#include<fcntl.h> #include<signal.h>  #define MAXMSG 128  /消息队列的最大长度 #define BUFSIZE 128  /缓冲区的最大长度  /*定义消息的数据结构*/ struct my_msg     long int mtype;  /消息类型

9、0;    char mtextMAXMSG;   /消息内容 msg;  int pid,pid1,pid2;/定义父进程和两个子进程的id标识 int i,j; char bufferBUFSIZE,msgtextMAXMSG; /定义缓冲区和接受暂存字符数组  void stop()    main()    &

10、#160;/*定义共享内存*/     int shmid1,shmid2;/定义2个共享存储区的内部标识      char *addr,*array;      /*创建并附接共享内存*/     shmid1=shmget(IPC_PRIVATE,BUFSIZE,IPC_CREAT|0666);      shm

11、id2=shmget(IPC_PRIVATE,BUFSIZE,IPC_CREAT|0666);      addr=(char *)shmat(shmid1,NULL,0);      array=(char *)shmat(shmid2,NULL,0);  /*创建消息队列并初始化*/      int msgid;     msgid=msgget(IP

12、C_PRIVATE,IPC_CREAT|0666);       pid=getpid();/获取父进程ID号      while(pid1=fork()=-1);      if(pid1>0)         while(pid2=fork()=-1);       

13、  if(pid2=0)               while(1)                   memset(buffer,'0',0);      &

14、#160;            scanf("%n%*c",buffer);/从终端输入字符串                    memset(msg.mtext,'0',0);      

15、;             strcpy(msg.mtext,buffer);                   msg.mtype=1;/设置消息类型为1           

16、        if(msgsnd(msgid,&msg,MAXMSG,0)<0)return 0;/向子进程1发送消息                    if(strcmp(buffer,"quit")=0)break;exit(0);elseprintf("Pleas

17、e input a line:n");/提示输入              while(1)                  signal(16,stop);/接收子进程发送的信号     

18、;            pause();/父进程挂起                 if(strcmp(addr,"quit")=0)break;/判断是否退出并终止循环         

19、0;        printf("Your message is:n%sn",addr);/输出从终端输入的内容                  if(strlen(array)!=0)/输出被抛弃的字符       

20、0;              printf("The characters deserted are:n%sn",array);                  memset(addr,'0',0); 

21、;                 printf("please input a line:n");wait(0);              wait(0);         &

22、#160;     /*断开附接*/              shmdt(addr);              shmdt(array);           

23、60;   /*撤销共享内存*/               shmctl(shmid1,IPC_RMID,0);              shmctl(shmid2,IPC_RMID,0);         

24、;     /*删除消息队列*/               msgctl(msgid,IPC_RMID,0);              exit(0);  else FILE *fp1,*fp2;    &

25、#160;    fp1=fopen("letter.txt","w");/打开文件           fp2=fopen("number.txt","w");           while(1)      

26、;         if(!msgrcv(msgid,&msg,BUFSIZE,0,0)return 0;/接收消息                i=0;                j=

27、0;               memset(msgtext,'0',sizeof(msgtext);                memset(array,'0',sizeof(array);      

28、;          strcpy(msgtext,msg.mtext);                strcpy(addr,msg.mtext); if(strcmp(msgtext,"quit")=0)   /判断是否退出,若是则向父进程发送信号并退出循环    

29、;                kill(pid,16);                     break;                while(i<strlen(msgtext)      /分类输入到文件,并将要抛弃的字符输入array存储区                   if(msgtex

温馨提示

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

评论

0/150

提交评论