1. 程式人生 > >程序1,2,3分別列印A,B,C,輸出10次,按ABC順序

程序1,2,3分別列印A,B,C,輸出10次,按ABC順序

我用了訊息佇列,沒有用fork(),直接寫了3 段程式,不知道對不對,歡迎指正

要按順序列印

程序1接到C,列印A,向佇列傳送A;

程序2接到A,列印B,向佇列傳送B;

程序3接到B,列印C,向佇列傳送C;

........

形成一個迴圈,接不到對應的訊息,就等待在msgrcv

佇列本身沒有訊息,程序1第一次列印前,先自己傳送C,之後就進入迴圈;

這裡我只給出程序1,程序23,與1類似,去掉進入迴圈前傳送的訊息,把迴圈內傳送和接受的訊息修改一下就行;

#include<stdio.h>
#include<sys/types.h>
#include<sys/ipc.h>
#include<sys/msg.h>
#include<string.h>

int main()
{
	key_t key = ftok("./msg", 'a');//create key for msg queue
	int msgid = msgget(key, IPC_CREAT|00666);//msgget
	if(msgid == -1)
	{
		perror("msgget error:");
		return 0;
	}
	printf("msgget...\n");
	//define struct for read and write;
	struct msgsbuf
	{
		int mtype;
		char mtext;
	}msg_sbuf;

	struct msgrbuf
	{
		int mtype;
		char mtext;
	}msg_rbuf;
	//contributes
//	msg_stat(msgid, msg_ginfo);
	//send c to msg queue
	msg_sbuf.mtype = 3;
	msg_sbuf.mtext = 'C';
	
	int ret = 0;
	ret = msgsnd(msgid, &msg_sbuf, 1, IPC_NOWAIT);
	if(ret == -1)
	{
		perror("send error:");
		return 0;
	}

	int i = 10;
	while(i)
	{
		memset(&msg_rbuf, 0, sizeof(msg_rbuf));	
		msgrcv(msgid, &msg_rbuf, 1, 3, MSG_NOERROR);
		if(msg_rbuf.mtext == 'C')
		{
			printf("A");
			fflush(stdout);
			i--;
			sleep(1);
			msg_sbuf.mtype = 1;
			msg_sbuf.mtext = 'A';
			msgsnd(msgid, &msg_sbuf, 1, IPC_NOWAIT);
		}
	}
	return 0;
}