使用fifo实现一个服务器端多个客户端通信

有名fifo默认是阻塞读,阻塞写的,如果要设置阻塞属性,可以再open()的时候进行设置

在阻塞情况下:实现服务器端可以不断读取客户端写到管道里面的文件流

这个里面有个重要的问题时,如果使用服务器端进行read(),读的buf的大小是多少呢?如果每一个客户端每次传过来的buf大小都不一样,那么服务器端使用read函数必然会造成数据读取不完整或者超出实际写进去的,这是因为,对于多个进程都在向fifo文件中写时,一个进程一个进程将要写的内容写进去,如果在读buf大小的数据的时候,有两个进程一前一后写入数据(在下次read()之前),那么这两个进程的写入数据就会混乱的读入读进程。

为了解决这一问题:

关键:统一buf的大小,也就是write read函数每次操作的buf的大小都是确定的,这样的话,每一个进程的数据就有了“原子性”,被封装在一个buf中,保证每一次读,都是一个完整的数据包

比如:

客户端有登录包,发送信息给其他客户端的信息包等等,将不同包的内容封装,这里就像一个协议,不同的数据包有不同的编号,比如,登录包,编号为1,信息包编号为2,这样,讲将要传递的内容拼接在一起,作为长度固定的整体,如果长度不够,填充特殊字符,就像ip数据报一样,这样,按照不同编号,服务器也对应了不同的解析buf的方法,这样就保证多个进程的数据可以完整的传递到服务器端了

代码:

client_0

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值