信号队列。

建立两个.c 建立子父进程,父进程发送消息到队列,子进程读取队列,另一个同样

这个程序不是很理想,无法办到一个程序输入quit,两个都退出

pid大于0为父程序,通过ftok函数创建消息队列,再是msgget获得队列的id号,接着的结构体是函数msgsnd函数第二个参数,其中的mtxet是用来存储正文信息的

#include <myhead.h>
struct msgbuf
{
    long mtype;
    char mtext[1000];
};
#define leng sizeof(struct msgbuf) - sizeof(long)
int main(int argc, const char *argv[])
{
    pid_t pid = fork();
    if (pid > 0)
    {
        key_t key = ftok("./", 'B');
        if (key == -1)
        {
            perror("ftok");
            return -1;
        }
        printf("键:%#x\n", key);
        int msgID = msgget(key, IPC_CREAT | 0664);
        if (msgID == -1)
        {
            perror("msgget");
            return -1;
        }
        printf("msgID = %d\n", msgID);

        struct msgbuf send;
        while (1)
        {
            printf("消息类型:");
            scanf("%ld", &send.mtype);
            getchar();
            printf("输入消息的正文:");
            fgets(send.mtext, sizeof(send.mtext), stdin);
            send.mtext[strlen(send.mtext) - 1] = '\0';
            msgsnd(msgID, &send, leng, 0);
            if (strcmp(send.mtext, "quit") == 0)
            {
                kill(pid, SIGTERM);
                break;
            }
        }
        if (msgctl(msgID, IPC_RMID, NULL) == -1)
        {
            printf("删除失败\n");
            return -1;
        }
        wait(NULL);//阻塞回收
        exit(EXIT_SUCCESS);
    }
    else if (pid == 0)
    {
        key_t key = ftok("./", 'C');
        if (key == -1)
        {
            perror("ftok");
            return -1;
        }
        int msgID = msgget(key, IPC_CREAT | 0664);
        if (msgID == -1)
        {
            perror("msgget");
            return -1;
        }

        struct msgbuf rcv;
        while (1)
        {

            msgrcv(msgID, &rcv, leng, 0, 0);
            printf("%s\n", rcv.mtext);
            if (strcmp(rcv.mtext, "quit") == 0)
            {
                break;
            }
        }
        exit(EXIT_SUCCESS);
    }
    else
    {
        perror("fork");
        return -1;
    }
}

 

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值