进程间的通信(八)

编写程序完成以下要求:

1.进程A向消息队列发送消息“hello world” 
2.进程B从消息队列读取消息,并打印
3.进程C向消息队列发送"自己的姓名"
4.进程D从消息队列中取出姓名字符串,并打印
 

消息队列也叫报文队列,是一个消息的链表。可以把消息看作是一个记录,具有特定的格式以及优先级。对消息队列具有写权限的进程可以按照一定的规则向消息队列中添加消息,而对消息队列具有写权限的进程可以从消息队列中读走消息。和管道相似的是,消息一旦从消息队列中被读走,则消息队列中便不在存在此条消息。

IPC消息队列的缺省最大数为16;

每个消息缺省最大值为8192字节;

队列中的最大值缺省为16384字节;

每个消息队列都有其对应的属性信息,存储在struct_msqid_ds结构体中。

每个消息队列都有一个对应的id,标识消息队列的唯一性。

程序如下:

#include <stdio.h>
#include <stdlib.h>
#include <sys/ipc.h>
#include <unistd.h>
#include <sys/msg.h>
#include <sys/types.h>
struct msg{
	char msg_str[128];
};

int main()
{
	int qid;
	struct msg mymsg;
	if(qid = msgget(0x66,0666|IPC_CREAT) < 0)
	  perror("msgget");

	int pid;
	pid = fork();
	if(pid < 0)
	  perror("fork");
	else if(pid == 0)
	{
		printf("This is A process!\n");
		sprintf(mymsg.msg_str,"hello world");
		
		if(msgsnd(qid,&mymsg,128,0) < 0)
		  perror("msgsnd");
	}
	else
	{
		if(fork() == 0)
		{
			printf("This is B process!\n");
			if(msgrcv(qid,&mymsg,128,0,0) < 0)
			  perror("msgrcv");

			printf("The msg is: %s\n",mymsg.msg_str);
		}
		else if(fork() == 0)
		{
			printf("This is the C process!\n");
			sprintf(mymsg.msg_str,"wangguagnjie");

			if(msgsnd(qid,&mymsg,128,0) < 0)
			  perror("msgsnd");
		}
		else
		{
			printf("This is D process!\n");
			if(msgrcv(qid,&mymsg,128,0,0) < 0)
			  perror("msgrcv");

			printf("The msg is: %s\n",mymsg.msg_str);
		}
	}
	return 0;
}

该程序利用fork函数创建了四个进程,分别完成发送和接受的任务。

程序运行结果如下:

猜你喜欢

转载自blog.csdn.net/Wangguang_/article/details/84998209