我有以下代码片段:
if (servsock == null) {
System.out.println("HELLO1!");
servsock = new ServerSocket(63456, 10);
System.out.println("HELLO2!");
}
try {
System.out.println("HELLO3!");
sock = servsock.accept();
} catch (Exception ex) {
if (servsock != null && !servsock.isClosed()) {
System.out.println("PICO1!");
servsock.close();
}
if (servsock != null && servsock.isClosed()) {
System.out.println("PICO2!");
manager.log("SERVER SOCKET closed and nulled.");
servsock = null;
}
sock = servsock.accept();
}
System.out.println("HELLO4!");
is = sock.getInputStream();
System.out.println("HELLO5!");
bis = new BufferedInputStream(is);
System.out.println("HELLO6!");
这段代码在一个可运行的run()
方法中运行,当文件被传输时,它应该停止每次通信。
奇怪的是,它不是一个循环。该代码确实接受,确实进行了文件传输,但我不明白为什么 HELLO1 再次出现在我的屏幕上。因此,我第二次尝试再次运行此代码时,给了我“连接被拒绝”。
“10”是我的一个hack,但原始代码也从不使用积压。
请问有什么建议吗?
运行执行前面的代码是:
final IClientInterface clientInterface = client.getClient();
final prgHolder = new ProgHolder();
Pong ftppong = new Pong();
ftppong.setFileNames(bout64.toByteArray());
ftppong.setDstFolder(dstFolder);
prgHolder.setName("pong");
prgHolder.setTask(pong);
Thread t = new Thread(new Runnable() {
public void run() {
try {
IClientInterface.execute(prgHolder);
} catch (Exception ex) {
ex.printStackTrace();
}
}
});
t.start();
现在的确切问题是,当我到达新的 ServerSocket(63456) 命令时,客户端会收到“连接被拒绝”,但远程 PC 中的程序是开放式和广泛的侦听器!“netstat”证实了这一点!
所以我从另一个窗口重新运行(第二次)程序,传递所有 HELLO 消息并完成工作!
然后 Thread 在远程 PC 中停止,并解除绑定端口 63456!
为什么它作为代码失败,但接受传入的请求?