进程间通信实验报告

时间:2024.4.7

软件学院计算机课程

实  验  报  告  册

课程名称     计算机操作系统                           

实验学期 20## 年至 20## 年 第  2 学期

学生所在院(系)       软件学院       

年级 11软件  专业班级   软工(1)  

学生姓名   朱水云     学号  1115114034  

指导教师       陈自刚       

实验最终成绩                        

软件学院实验室制

2012 年 4 月

实验报告( 二 )

实验名称:进程间通信 

实验时间:20##年4月18号    

实验性质                    


第二篇:进程间通信实验报告


进程间通信实验报告

班 级:10网工三班 学生姓名:谢昊天 学号:1215134046

实验目的和要求:

Linux系统的进程通信机构 (IPC) 允许在任意进程间大批量地交换数据。本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息量机制。

实验内容与分析设计:

(1)消息的创建,发送和接收。

①使用系统调用msgget (), msgsnd (), msgrev (), 及msgctl () 编制一长度为1k的消息的发送和接收程序。

②观察上面的程序,说明控制消息队列系统调用msgctl () 在此起什么作用?

(2)共享存储区的创建、附接和段接。

使用系统调用shmget(),shmat(),sgmdt(),shmctl(),编制一个与上述功能相同的程序。

(3)比较上述(1),(2)两种消息通信机制中数据传输的时间。

实验步骤与调试过程:

1.消息的创建,发送和接收:

(1)先后通过fork( )两个子进程,SERVER和CLIENT进行通信。

(2)在SERVER端建立一个Key为75的消息队列,等待其他进程发来的消息。当遇到类型为1的消息,则作为结束信号,取消该队列,并退出SERVER 。SERVER每接收到一个消息后显示一句“(server)received”。

(3)CLIENT端使用Key为75的消息队列,先后发送类型从10到1的消息,然后退出。最后的一个消息,既是 SERVER端需要的结束信号。CLIENT每发送一条消息后显示一句“(client)sent”。

(4)父进程在 SERVER和 CLIENT均退出后结束。

2.共享存储区的创建,附接和断接:

(1)先后通过fork( )两个子进程,SERVER和CLIENT进行通信。

(2)SERVER端建立一个KEY为75的共享区,并将第一个字节置为-1。作为数据空的标志.等待其他进程发来的消息.当该字节的值发生变化时,表示收到了该消息,进行处理.然后再次把它的值设为-1.如果遇到的值为0,则视为结束信号,取消该队列,并退出SERVER.SERVER每接收到一次数据后显示”(server)received”.

(3)CLIENT端建立一个为75的共享区,当共享取得第一个字节为-1时, Server端空闲,可发送请求. CLIENT 随即填入9到0.期间等待Server端再次空闲.进行完这些操作后, CLIENT退出. CLIENT每发送一次数据后显示”(client)sent”.

(4)父进程在SERVER和CLIENT均退出后结束。

实验结果:

1.消息的创建,发送和接收:

由 Client 发送两条消息,然后Server接收一条消息。此后Client Server交替发送和接收消息。最后一次接收两条消息。Client 和Server 分别发送和接收了10条消息。message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全可能继续睡眠,造成上面现象。在多次send message 后才 receive message.这一点有助于理解消息转送的实现机理。

2.共享存储区的创建,附接和断接:

在运行的过程中,发现每当client发送一次数据后,server要等大约0.1秒才有响应。同样,之后client又需要等待大约0.1秒才发送下一个数据。出现上述的应答延迟的现象是程序设计的问题。当client端发送了数据后,并没有任何措施通知server端数据已经发出,需要由client的查询才能感知。此时,client端并没有放弃系统的控制权,仍然占用CPU的时间片。只有当系统进行调度时,切换到了server进程,再进行应答。这个问题,也同样存在于server端到client的应答过程之中。

3 比较两种消息通信机制中的数据传输的时间:

由于两种机制实现的机理和用处都不一样,难以直接进行时间上的比较。如果比较其性能,应更加全面的分析。

(1)消息队列的建立比共享区的设立消耗的资源少.前者只是一个软件上设定的问题,后者需要对硬件操作,实现内存的映像,当然控制起来比前者复杂.如果每次都重新进行队列或共享的建立,共享区的设立没有什么优势。

(2)当消息队列和共享区建立好后,共享区的数据传输,受到了系统硬件的支持,不耗费多余的资源;而消息传递,由软件进行控制和实现,需要消耗一定的CPU资源.从这个意义上讲,共享区更适合频繁和大量的数据传输。

(3)消息的传递,自身就带有同步的控制.当等到消息的时候,进程进入睡眠状态,不再消耗CPU资源.而共享队列如果不借助其他机制进行同步,接受数据的一方必须进行不断的查询,白白浪费了大量的CPU资源.可见消息方式的使用更加灵活。

疑难小结:

通过本次实验让我了解了进程间通信,message的传送和控制并不保证完全同步,当一个程序不再激活状态的时候,它完全可能继续睡眠,在多次send message 后才 receive message.这一点有助于理解消息转送的实现机理。并且了解了只有当系统进行调度时,切换到了server进程,再进行应答。这个问题,也同样存在于server端到client的应答过程之中。加深了对进程概念的理解,明确进程间通信的原理,进一步认识并发执行的实质。巩固了课本上所学到的知识。

主要算法和程序清单:

1.消息的创建,发送和接收:

#include <stdio.h>

#include <sys/types.h>

#include <sys/msg.h>

#include <sys/ipc.h>

#define MSGKEY 75 /*定义关键词MEGKEY*/

struct msgform /*消息结构*/

{

long mtype;

char mtexe[100]; /*文本长度*/

}msg;

int msgqid,i;

void CLIENT( )

{

int i;

msgqid=msgget(MSGKEY,0777|IPC_CREAT);

for(i=10;i>=1;i--)

{

msg.mtype=i;

printf("(client)sent\n");

msgsnd(msgqid,&msg,1030,0); /*发送消息msg入msgid消息队列*/ }

exit(0);

}

void SERVER( )

{

msgqid=msgget(MSGKEY,0777|IPC_CREAT); /*由关键字获得消息队列*/ do

{

msgrcv(msgqid,&msg,1030,0,0); /*从队列msgid接受消息msg*/

printf("(server)receive\n");

}while(msg.mtype!=1); /*消息类型为1时,释放队列*/

msgctl(msgqid, IPC_RMID,0);

}

main()

{

if(fork())

{

SERVER();

wait(0);

}

else CLIENT( );

}

2.共享存储区的创建,附接和断接:

#include<sys/types.h>

#include<sys/msg.h>

#include<sys/ipc.h>

#define SHMKEY 75 /*定义共享区关键词*/

int shmid,i;

int *addr;

CLIENT()

{

int i;

shmid=shmget(SHMKEY,1024, 0777|IPC_CREAT); /*获取共享区,长度1024,关键词SHMKEY*/

addr=shmat(shmid,0,0); /*共享区起始地址为addr*/

for(i=9;i>=0;i--)

{

while(*addr!= -1);

printf("(client)sent\n"); /*打印(client)sent*/

*addr=i; /*把i赋给addr*/

}

exit(0);

}

SERVER()

{

do

{

while(*addr = =-1);

printf("(server)received\n%d",*addr); /*服务进程使用共享区*/

if(*addr!=0)

*addr=-1;

} while(*addr);

wait(0);

shmctl(shmid,IPC_RMID,0);

}

main()

{

shmid=shmget(SHMKEY,1024,0777|IPC_CREAT); /*创建共享区*/

addr=shmat(shmid,0,0); /*共享区起始地址为addr*/

*addr=-1;

if(fork())

{

SERVER();

}

else

{

CLIENT();

}

}

更多相关推荐:
操作系统实验报告2-进程间通信

实验报告20xx20xx学年第1学期课程名称实验名称实验时间指导单位20xx操作系统原理实验2进程间通信年10月10日软件工程系指导教师杨健学生姓名班级学号专业计算机软件与服务外包学院系软件工程系12345

操作系统程序进程通信实验报告

进程通信指导老师夏建一实验题目进程通信上机实验消息缓冲通信二算法思想1在进程管理调度实验基础上加入进程通信的功能采用消息缓冲通信机制进行通信2P1发送数据给P2P2排序后发送给P3P3接收数据并输出3要发送的数...

实验三 进程通讯实验报告

实验三进程通讯实验报告姓名学号实验题目进程通讯消息队列与共享存储区实验目的1掌握进程间通讯的编程方法2加深对进程并发执行的理解3学习利用消息队列和共享存储区实现进程通信的方法实验内容设计一个多进程并发运行的程序...

实验三 进程通信 实验报告

北京联合大学信息学院操作系统课程实验报告实验名称实验三进程间通信姓名学号专业编制时间20xx年5月2日指导教师北京联合大学信息学院编制一信号机制实验1信号机制实验11题目描述1编写程序用fork创建两个子进程再...

操作系统实验报告进程的管道及消息通信

操作系统实验报告进程的管道及消息通信,内容附图。

操作系统进程创建及通信实验报告

武汉工程大学计算机科学与工程学院操作系统实验报告一实验目的创建进程实现消息通信和共享内存通信了解进程的创建退出和获取进程信息掌握通过内存印象文件和管道技术实现进程通信二实验内容本例用三种方法实现进程通信仅用于示...

实验五 进程间通信

实验五进程间通信UNIXLINUX系统的进程间通信机构IPC允许在任意进程间大批量地交换数据本实验的目的是了解和熟悉LINUX支持的信号机制管道机制消息队列通信机制及共享存储区机制51信号机制实验一实验目的1了...

进程通信实验报告

西安电子科技大学操作系统原理实验报告题目进程通信实验报告班级030912姓名王增祥学号03091168实验内容补充说明一分析和设计1理论分析每个Windows进程都是由一个执行体进程块EPROCESS表示API...

基于管道的进程通信 操作系统实验报告2

内蒙古师大计算机与信息工程学院操作系统课程实验报告

进程间通信实验报告

进程间通信实验报告班级10网工三班学生姓名谢昊天学号1215134046实验目的和要求Linux系统的进程通信机构IPC允许在任意进程间大批量地交换数据本实验的目的是了解和熟悉Linux支持的消息通讯机制及信息...

单片机实验报告串行口

单片机实验报告实验名称姓名学号班级实验时间串行通信实验魏冶090402105光电一班20xx1129南京理工大学紫金学院电光系一实验目的1理解单片机串行口的工作原理2学习使用单片机的TXDRXD口3了解MAX2...

串口通信实验报告

基于Labview的串行通信接口实验报告一实验目的通过软件Labview编写前面板和程序框图通过该面板实现计算机与外围设备的串口通信设置好通信端口波特率等参数后在输入控件中输入数据字符当点击发送按钮时下位机发生...

进程通信实验报告(29篇)