У меня есть следующий поток, который принимает входящие соединения через определенный порт:
public class ClientThread implements Runnable {
ServerSocket serverSocket;
Socket clientSocket;
int serverPort = 6500;
private String serverIpAddress = "127.0.0.1";
DataInputStream is;
ObjectOutputStream os=null;
Coordinate coord;
protected BlockingQueue queue = null;
public ClientThread(BlockingQueue queue) {
this.queue = queue;
}
public void run() {
try {
InetSocketAddress serverAddr = new InetSocketAddress(
serverIpAddress, serverPort);
serverSocket = new ServerSocket();
serverSocket.bind(serverAddr);
System.out.println("s-a creat");
} catch (UnknownHostException e) {
System.err.println("Don't know about host");
} catch (IOException e) {
System.err.println("Couldn't get I/O for the connection to host");
}
try {
clientSocket = serverSocket.accept();
System.out.println("S-a conectat clientul de monitorizare!");
os=new ObjectOutputStream(clientSocket.getOutputStream());
try{
while(true){
coord=(Coordinate)queue.take();
System.out.println(coord.getLat()+coord.getLon()+coord.getwId());
os.writeObject(coord);
os.flush();
}
} catch(Exception e) {
e.printStackTrace();
}
} catch (IOException e) {
System.out.println(e);
try {
clientSocket.close();
os.close();
}catch(Exception e1) {
e1.printStackTrace();
}
}
}
}
Объект, который я пытаюсь отправить, является экземпляром следующего класса:
public class Coordinate implements Serializable{
private final int lon;
private final int lat;
private final int workerId;
public Coordinate(int lat, int lon, int workerId) {
this.lat = lat;
this.lon = lon;
this.workerId=workerId;
}
public int getLon() {
return lon;
}
public int getLat() {
return lat;
}
public int getwId() {
return workerId;
}
}
Но когда я запускаю поток и принимаю соединение, я получаю следующую ошибку:
java.net.SocketException: Software caused connection abort: socket write error
at java.net.SocketOutputStream.socketWrite0(Native Method)
at java.net.SocketOutputStream.socketWrite(Unknown Source)
at java.net.SocketOutputStream.write(Unknown Source)
at java.io.ObjectOutputStream$BlockDataOutputStream.drain(Unknown Source)
at java.io.ObjectOutputStream$BlockDataOutputStream.setBlockDataMode(Unknown
at java.io.ObjectOutputStream.writeNonProxyDesc(Unknown Source)
at java.io.ObjectOutputStream.writeClassDesc(Unknown Source)
at java.io.ObjectOutputStream.writeOrdinaryObject(Unknown Source)
at java.io.ObjectOutputStream.writeObject0(Unknown Source)
at java.io.ObjectOutputStream.writeFatalException(Unknown Source)
at java.io.ObjectOutputStream.writeObject(Unknown Source)
at servers.ClientThread.run(ClientThread.java:55)
at java.lang.Thread.run(Unknown Source)
Кто-нибудь знает, что не так?
Эта ошибка java.net.SocketException: программно вызванное прерывание соединения появляется, когда происходит сбой одного из сокетов .... в моем случае это был конец, который подключился к ClientThread () и когда я пытался записать в буфер появилась ошибка.