我用了消息队列,没有用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;
}