0

我有以下代码片段:

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!

为什么它作为代码失败,但接受传入的请求?

4

1 回答 1

1

根据此代码,您应该只看到一次 HELLO1。然而,这段代码的调用者很可能处于循环中,否则检查 servsock 的先前值是没有意义的。

这是要做什么?

servsock = null;
}
sock = servsock.accept();

当您遇到异常时,不要继续,就好像它没有发生一样。

如果您想了解您的代码在做什么,我建议您使用调试器来单步执行您的代码。

于 2011-01-14T16:22:09.327 回答