标签:sockets client-server java visitor
我有一个多线程服务器,正在等待套接字连接.
第一次消息交换始终是同一类型,客户端发送一个带有身份验证详细信息(userid / pwd)的对象,服务器将对其进行检查,然后通过身份验证是否通过身份验证.
在第一次交换消息之后,客户端将发送一些请求,这些请求对应于服务器能够执行的各种任务.
我该如何建模这些异乎寻常的请求?特别是我的问题是关于使用InputObjecStream / OutputObjectStream在客户端和服务器之间发送的对象的类型
我有两个想法:
>使用具有2个属性的“通用消息”对象:任务标识符和不具有通用属性的HashMap,它们能够携带为执行任务而请求的各种类型的参数.
>对于每种任务类型都有一个对象,这种解决方案是“更干净的”,但是我不知道如何使服务器理解接收到的消息的类型,我想到了一系列从客户端接收到的消息的对象转换到每个可能的“特定任务消息”,而忽略了许多CastException.听起来很糟糕,有什么办法可以避免这种情况?
解决方法:
第一种方法非常通用,但是很难维护.一段时间后,您会发现您不再记得该通用映射中应包含哪种对象.您必须保持字典同步.
第二种方法要好得多.本质上,您会收到带有各种子类的抽象Request对象.基类可以保存一些常规信息.通常,您将使用多态性并在每个子类中实现操作,从而覆盖Request类的抽象方法.但是您不能这样做,因为请求对象必须拥有服务器端逻辑.
您在这里可以做的最好的是visitordesign pattern.有了它,以使代码稍微模糊的代价,您将获得非常通用和安全的设计.一段时间后,instanceof往往很难看.
标签:sockets,client-server,java,visitor 来源: https://codeday.me/bug/20191127/2076517.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。