gpt4 book ai didi

Java - 在客户端识别来自服务器的发送到一个和发送到所有的消息

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:06:29 25 4
gpt4 key购买 nike

我正在开发一个服务器/客户端应用程序,它允许多个客户端在任何给定时间连接到服务器。对于每个客户端,服务器设置一个 ClientHandler具有连接到此套接字的客户端的输入和输出流的对象。通过这个连接,客户端可以在程序运行的任何时候自由地向服务器发送多条消息,服务器将根据消息做出响应。

我需要实现的是一种在特定时间向所有当前连接的客户端发送消息的机制。我通过将所有输出流存储在 ArrayList<PrintWriter> 中来完成此操作。这将允许向所有客户端发送相同的消息。

我正在努力解决的问题是:

当接收到对客户端来说是单独的消息时,客户端 GUI 会相应地更新(只能发送选定数量的消息,因此只有选定数量的来自服务器的可能响应,由客户端处理-side if 语句)。但是,当客户端收到一条发送给所有客户端的消息时,我希望客户端以完全不同的方式更新 GUI。

考虑到两种形式的输入来自同一个输入流,我可以看出这很困难,我预计我将不得不使用 PrintWriter 声明任何导致输出的方法。必须制作synchronized .但是,有没有办法在使用相同的 PrintWriter 的同时处理不同的输入?在所有?这是否必须使用进一步的 if 来完成?语句还是可以使用单独的 Thread 来完成在客户端处理发送给所有客户端的消息?

感谢您的任何建议,如果您认为可以提供帮助,请随时索取我现有代码的部分内容!

标记

最佳答案

您首先缺少服务器和客户端之间的协议(protocol)!

显然,服务器可以发送两种类型的消息“响应”和“广播”。一种相当简单的方法是标记您的消息:例如如果是对请求的响应,请在消息前加上“R”前缀;如果是无人值守的广播消息,请在消息前加上“B”前缀。 (这一切都取决于服务器和客户端之间的通信是如何进行的。)

您的客户端是否需要不同的线程来处理消息是完全不同的事情。如果客户端中的处理 Activity 会阻止及时读取套接字,则拥有不同的线程很有用。然后,您可能会考虑让一个 I/O 线程进行通信并将消息分派(dispatch)给不同的“处理程序”(可能是其他线程)进行处理。 (这个 I/O 线程也可以删除标签,这样现有的处理代码就不需要了解与服务器的较低协议(protocol)。)

类似的推理可能适用于您的服务器端。根据请求的交互和处理动态,您可能会使用多个线程。然后你应该有一个正在与客户端和其他正在做工作(生成响应或广播消息)的 I/O

关于Java - 在客户端识别来自服务器的发送到一个和发送到所有的消息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36089536/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com