System V 消息队列 (每个客户一个队列)

本文介绍了如何将一个服务器与多个客户端的交互模式改造成每个客户端都有自己的消息队列来接收服务器响应。服务器使用一个公共队列接收请求,而客户端通过IPC_PRIVATE创建私有队列并传递给服务器,以便服务器能定向回应。服务器程序以并发模式运行,对每个客户端fork一次。
摘要由CSDN通过智能技术生成

    今天将之前的一个服务器和多个客户端的例子改成给去往服务器的所有客户请求使用一个队列,给每个客户使用一个队列接收去往各个客户的服务器应答。

     下面给出这样的设计:

    服务器的队列有一个对客户来说众所周知的键,但是各个客户以IPC_PRIVATE键创建各自的队列,这里并未随请求传递本进程id,而是由每个客户把自己的私用队列的标识符传递给服务器,服务器把自己的应答发送到由客户指出的队列中。我们还以并发服务器模型编写这个服务器程序,给每个客户fork一次。。。

首先给出客户端的代码:

#include"uitil.h"

int main(int argc,char*argv[])
{
    int readid,writeid;
    //打开服务器创建的MQ_KEY1    
    writeid = msgget(MQ_KEY1,0);
    if(writeid == -1){
        cout << "msgget error." << endl;
        exit(1);
    }
    //客户端创建自己的消息队列
    readid = msgget(IPC_PRIVATE,SVMSG_MODE | IPC_CREAT);
    if(readid ==
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值