微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

C网络多应用协议

我正在为C中的项目编写Client / Server应用程序.整个申请协议由工作组提供或讨论.主要思想是我们有3个协议.

>文本协议:在客户端和服务器之间以字符串格式发送和接收一些信息.
>二进制协议:客户端连续向服务器发送一些状态数据.
>二进制协议:客户端连续发送一些数据,如声音/视频/图像/文本

所有协议都应该在不同的端口上运行.
我实现了一个Socket-Class,负责创建和监听socket,接受来自客户端的连接.还有一个接收/发送基于字符串的数据和接收/发送基于二进制的数据的功能.

在下一步中,我想定义3个类.他们每个人都应负责在新线程中创建一个套接字,并负责为该端口定义的协议(s.1-3).所以最后我将获得3个套接字(一个端口为1个套接字).

我的问题是,如果我认为正确的方向?也许你可以推荐我的一些设计模式来使用不同的应用程序协议.如果您可以向我推荐一些项目或代码,这可能与我的项目类似,那将是很棒的.

谢谢.

解决方法

您应该将套接字类与3个协议处理程序分离 – 在Socket上没有文本和二进制数据处理的方法,或者您无意中鼓励人们在同一个套接字上混合和匹配数据类型,这显然不是您想要的.

您的套接字应该提供简单的连接/断开,数据传输和接收功能,然后发送/接收数据的解码和编码在不同的对象中完成,可能从3个新类(每个协议一个)中选择.

总的来说,我质疑文本数据的使用.与您可以命名的几乎任何序列化库相比,它效率低下.您可能会为许多硬编写的数据解析和错误检查代码交换一些额外的可调试性,以及伴随的cpu周期浪费.如果文本数据相当简单(实际上并不像XML那样结构化),那么这不是一个问题.

如果状态信息不是关键任务,则协议2.可以使用UDP而不是TCP实现.这是你必须管理的一个较少的连接.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐