多个客户端与服务器端发送消息案例

本文提供了一个案例,演示如何使用消息队列让多个客户端与服务器端进行通信。客户端通过在消息前附加自己的进程号发送消息到1号通道,服务器解析并根据进程号回发消息。关键点包括指定发送通道号、接收时刷新缓冲区以及正确计算消息长度。

案例:用消息队列实现许多客户端和服务器端的通信,要求是,许多客户端都可以向服务器端发送消息,服务器端在接受这些消息之后,再将消息回发给对应的客户端。

解决思路:所有客户端都往1号通道上发送消息,并且在发送的内容的最前面放上自己进程的进程号,那么当服务器端收到中众多客户端发来的消息之后,通过解析主要内容的最前面内容,拿出对应客户端进程号,将其作为发送通道发送给对应的客户端,那么客户端接受的消息就来自以自己进程号为通道号的消息,服务器在1号通道等待接受数据,没有数据就阻塞。

注意:

1)发送消息的,提前设定要发的通道号(buf.channel=1,就说明要发送的通道号是1号);而接受消息时直接将接受通道号作为参数传过去。

2)每次接受前,读前都要刷新缓冲区

3)因为客户端把自己的进程号放在发送消息的前面,(假如是进程号为

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值