socket catch子句中的系统输出/错误流仅在调试模式下有效

时间:2013-05-16 14:39:08

标签: java netbeans

与主题一样 - 系统输出和错误流似乎在内核类的“更新”方法中的catch子句中“冻结”。奇怪的是,当我调试项目并停在System.out线时,我甚至可以删除突破,一切正常。

除了上一次System.out之外的所有内容都被执行,即使我替换默认的System.out也不行。

目前我正在连接后断开用户连接。

我的代码,StartServer.java:

public class StartServer {

    public static void main (String[] args) {
        Kernel kernel = new Kernel(4444);
        kernel.run();
        while (true) {
            kernel.update();
        }
    }

}

Kernel.java:

import java.io.IOException;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.ArrayList;
import java.util.logging.Level;
import java.util.logging.Logger;

public class Kernel {

    ArrayList<Socket> clients;
    ServerSocket socket;

    public Kernel(int port) {
        try {
            socket = new ServerSocket(port);
            clients = new ArrayList<>();
            System.out.println("Server initialized");
        } catch (IOException ex) {
            Logger.getLogger(StartServer.class.getName()).log(Level.SEVERE, null, ex);
        }
    }

    public void run() {
        Thread thread = new Thread(){
            public void run() {
                try {
                    while (true) {
                        Socket client = socket.accept();
                        clients.add(client);
                        System.out.println("New user on the server!");
                    }
                } catch (IOException ex) {
                    Logger.getLogger(Kernel.class.getName()).log(Level.SEVERE, null, ex);
                }
            }
        };
        thread.start();
    }

    public void update() {
        for (int i=0; i<clients.size(); i++) {
            Socket s = clients.get(i);
            try {
                /*String result;
                if (s.getInputStream().available()!=0) {
                    byte[] byteRes = new byte[s.getInputStream().available()];
                    char[] charRes = new char[s.getInputStream().available()];
                    s.getInputStream().read(byteRes);
                    for (int i2=0; i2<charRes.length; i2++) {
                        charRes[i2] = (char) byteRes[i2];
                    }
                    result = String.copyValueOf(charRes);
                    System.out.println(result);
                }*/
                throw new IOException();
            } catch (IOException ex) {
                try {
                    System.out.println("Client disconnected"); //working only in debug mode
                    clients.remove(s);
                    s.close();
                    i--;
                } catch (IOException ex1) {
                    Logger.getLogger(Kernel.class.getName()).log(Level.SEVERE, null, ex1);
                }
            }
        }
    }

}

2 个答案:

答案 0 :(得分:1)

在StartServer类中更改无限循环,如下所示:

while (true) {
    try {
        Thread.sleep(10);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    kernel.update();
}

答案 1 :(得分:0)

尝试添加

System.out.flush();

在System.out.println()

之后