- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
基本上我在写一个客户端-服务器多人游戏。我有一个 SeverCommunicationThread,如果他收到 RequestForGame 创建一个 gameThread,它会创建一个 gameThread。当我发送 RequestForGame 异常时抛出 java.io.StreamCorruptedException: invalid type code: 00我假设这是因为两个线程都试图读取相同的 ObjectInputStream,我对它的工作原理不太了解,我只知道如何使用它。你能帮我理解问题是什么以及如何解决吗?谢谢:)
public class ServerCommunicationThread extends Thread{
private Socket connectionSocket;
private ObjectInputStream inFromClient;
private ObjectOutputStream outToClient;
private String nickname;
private ServerModelManager model;
public ServerCommunicationThread(Socket connectionSocket,
ServerModelManager model) throws IOException {
this.connectionSocket = connectionSocket;
inFromClient = new ObjectInputStream(connectionSocket.getInputStream());
outToClient = new ObjectOutputStream(connectionSocket.getOutputStream());
this.model = model;
start();
}
public void run() {
try {
String nickname = (String) inFromClient.readObject();
if (model.exists(nickname)){
System.out.println(nickname + " already exists");
outToClient.writeObject(new MessageForClient("Please choose another nickname"));
}
else
{
System.out.println(nickname + " connected, adding to list");
model.addClient(nickname, connectionSocket,outToClient,inFromClient);
this.nickname=nickname;
}
while(true){
Object o= inFromClient.readObject();//StreamCorruptedexception
if(o instanceof RequestForGame)
{
RequestForGame r=(RequestForGame)o;
String userToPlayWith=r.getUserToPlayWith();
if(userToPlayWith.equals(nickname))
{
String message="Playing with yourself makes your palms hairy, choose another opponent";
outToClient.writeObject(message);
}
else
{
System.out.println("received request to play with "+userToPlayWith+". starting game");
ClientRepresentative client1=model.getClient(nickname);
ClientRepresentative client2=model.getClient(userToPlayWith);
ServerGameThread s=new ServerGameThread(client2,client1,client2.getInStream(),client1.getInStream(),client1.getOutStream(),client2.getOutStream());
}
}
else if(o instanceof String)
{
String s=(String) o;
if(s.equals("i want to quit"))
{
model.deleteClient(nickname);
inFromClient.close();
String q="quit";
outToClient.writeObject(q);
connectionSocket.close();
System.out.println(nickname+"has quit without exc");
}
}
}
} catch (EOFException e) {
System.out.println(nickname+" has quit");
}
catch (SocketException e)
{
System.out.println(nickname+" has quit");
}
catch (Exception e) {
e.printStackTrace();
}
}
}
public class ServerGameThread extends Thread {
private ClientRepresentative client1,client2;
private ObjectInputStream inFromClient1,inFromClient2;
private ObjectOutputStream outToClient1,outToClient2;
private Field gameField;
public ServerGameThread(ClientRepresentative client1, ClientRepresentative client2,ObjectInputStream inFromClient1,ObjectInputStream inFromClient2,ObjectOutputStream outToClient1,ObjectOutputStream outToClient2)
{
System.out.println("startin game thred");
this.client1=client1;//client 1 goes first
this.client2=client2;//client 2 started game
this.inFromClient1=inFromClient1;
this.inFromClient2=inFromClient2;
this.outToClient1=outToClient1;
this.outToClient2=outToClient2;
gameField=new Field();
System.out.println("check");
start();
}
public void run()
{
System.out.println("Starting game. players: "+client1.getNickname()+";"+client2.getNickname());
try {
outToClient1.writeObject(gameField);
outToClient2.writeObject(gameField);
while(true)
{
try {
System.out.println("listening to "+client1.getNickname());
Object o1=inFromClient1.readObject();//read move from client 1.**//StreamCorruptedexception**
while(!(o1 instanceof PlayerMove))
{
o1=inFromClient1.readObject();//read move from client 1.
}
PlayerMove move1=(PlayerMove)o1;
System.out.println("received move "+move1+" sending to "+client2.getNickname());
outToClient2.writeObject(move1);
System.out.println("listening to "+client2.getNickname());
Object o2=inFromClient2.readObject();//read move from client 1.
while(!(o2 instanceof PlayerMove))
{
o2=inFromClient2.readObject();//read move from client 1.
}
PlayerMove move2=(PlayerMove)o2;
System.out.println("received move "+move2+" sending to "+client1.getNickname());
outToClient1.writeObject(move2);
}
catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
model.addClient 方法虽然我不认为问题出在这里
public void addClient(String nickname, Socket clientSocket,ObjectOutputStream stream,ObjectInputStream inStream)
{
clients.addClient(nickname, clientSocket,stream,inStream);//add to arraylist
//send client list to all clients
String[] users=this.getAvailableClients();
ObjectOutputStream[] streams=clients.getOutStreams();
for(int i=0;i<streams.length;i++)
{
try {
streams[i].writeObject(users);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
将对象发送到服务器的客户端代理,这些方法由 GUI 中的用户操作触发
public class Proxy {
final int PORT = 1337;
String host;
String nickname;
private Socket clientSocket;
private ObjectOutputStream outToServer;
private ObjectInputStream inFromServer;
private ClientModelManager manager;
public Proxy(String nickname,String host,ClientModelManager manager)
{
this.nickname=nickname;
this.host=host;
this.manager=manager;
this.connect(nickname);
}
public void connect(String nick)
{
Socket clientSocket;
try {
clientSocket = new Socket(host, PORT);
System.out.println("client socket created");
outToServer = new ObjectOutputStream(clientSocket.getOutputStream());
inFromServer=new ObjectInputStream(clientSocket.getInputStream());
outToServer.flush();
outToServer.writeObject(nick);
ClientReceiverThread t=new ClientReceiverThread(inFromServer,manager);
t.start();
} catch (Exception e) {
e.printStackTrace();
}
}
public void makeRequest(String user)
{
try
{
outToServer.writeObject(new RequestForGame(user));
}
catch(IOException e)
{
e.printStackTrace();
}
}
public void quit()
{
try {
outToServer.writeObject(new String("i want to quit"));
//clientSocket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
public void sendMove(PlayerMove move)
{
try {
outToServer.writeObject(move);
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
最佳答案
这个问题可能会发生,如果你
ObjectInputStream
或ObjectOutputStream
,而不是在套接字的生命周期内使用相同的;关于java.io.StreamCorruptedException : invalid type code: 00,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10775709/
我有一个客户端和服务器应用程序,它们使用 TCP 上的序列化来传输消息。反序列化对象时出现以下错误: 对于分析此问题的原因或可能的后续步骤有什么想法吗? java.io.StreamCorrupted
我有一个 Java 客户端-服务器(如果这里有人知道的话,可以使用 ocsf)基础设施,我用它来将文件从客户端上传到服务器。客户端实际上是一个 Android 应用程序(不确定在这种情况下是否那么重要
我正在制作一个即时消息应用程序,在其中我在两部手机之间建立了 TLS 连接,其中一部充当服务器,另一部充当客户端。尝试发送消息时,我在客户端收到此异常,服务器尝试在线发送消息 inputStream
这是我的代码: try { Uri uri = Uri.parse("file:///storage/emulated/0/Download/information.
大家好,我必须编写一个通过套接字连接进行通信的服务器。客户端将对象发送到服务器,服务器将其打印到控制台。 public class ConnectionListener { ServerSocket
大家好,我必须编写一个通过套接字连接进行通信的服务器。客户端将对象发送到服务器,服务器将其打印到控制台。 public class ConnectionListener { ServerSocket
我的服务器在线程中运行此代码,以便我可以在等待客户端连接时与 GUI 交互。(目前我只使用 1 个客户端和 1 个服务器。) @Override public void run() { Soc
我完全不知道为什么会这样。我有一个 javascript 文件部署到三个测试箱。在其中两个上,当我点击页面(如下)时出现以下错误。如您所见,它表示流 header 是一串零,并且它正在读取的文件中没有
我正在编写一个 netty 客户端和服务器应用程序,它将 JVM GC 统计信息写入时间序列数据库以分析大约 300 台服务器。但是我的管道抛出了很多这样的异常: 10/02/2012 10:14:2
我正在尝试流式传输 ObjectOutput,但出现上述错误。 代码: private void writelogin(int i, int j, int k, int c4, int l, int
我试图通过用派生字段替换动态字段(没有底层数据库表示的 transient getter)来提高性能,以便我可以使用 Criteria 等来查询我的模型。最初的动态字段非常简单: Client res
这个问题已经有答案了: StreamCorruptedException: invalid type code: AC (1 个回答) 已关闭10 年前。 我有一个用于序列化对象的 UserData
我有一个序列化类,我需要通过蓝牙将其作为对象发送,并且还实现了 Runnable。因此,我首先设置了一些变量,然后将其作为对象发送给另一台 Android 设备执行,然后将其结果设置为一个变量,并在其
因此,我设置了Elasticsearch,使服务器运行了。当我连接到http://localhost:9200/时,我会收到状态消息。是版本号1.4.3。 现在我下载Kibana 3.1.2。如自述文
This question is unlikely to help any future visitors; it is only relevant to a small geographic are
我正在尝试从 SD 卡读取 XML 文件并将其转换为对象类型。问题是当我使用 FileInputStream 读取文件并将 FileInputStream 对象传递给 ObjectInputStrea
问题是我得到 java.io.StreamCorruptedException: invalid type code: 9E 每次代码都不同。 我有一个客户端-服务器应用程序,当客户端处于上传状态而服
我想将inputStream (HttpRequest.getInputStream())转换为对象。 try { ObjectInput ois = new ObjectInputS
我有一个客户端-服务器应用程序。客户端发送一个对象,服务器发回相同的对象,这是一个简单的回显服务器。如果我为每个新请求创建一个新的 Client 实例,下面的代码就可以正常工作。但是,如果我使用客户端
我正在使用 java NIO 数据报 channel (阻塞模式)。我想将一个对象从一侧传输到另一侧。这就是我在发送方所做的事情: ByteArrayOutputStream ba
我是一名优秀的程序员,十分优秀!