Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/multithreading/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 一旦进入新的螺纹,插座就关闭_Java_Multithreading_Sockets - Fatal编程技术网

Java 一旦进入新的螺纹,插座就关闭

Java 一旦进入新的螺纹,插座就关闭,java,multithreading,sockets,Java,Multithreading,Sockets,我正在尝试创建一个多线程双工聊天服务器。在将代码移动到线程中之前,我已经让它工作得很好了,但是现在每当线程试图访问套接字时,我就会得到“SocketException:Socket已关闭” 我和我的老师都搞不懂。(老师对Java的了解甚至比我还少;他是个C语言的家伙)。看起来套接字是打开的,但一旦进入线程,它就关闭了 我做错了什么 客户端代码: public class Client { public static void main(String[] args) throws IOEx

我正在尝试创建一个多线程双工聊天服务器。在将代码移动到线程中之前,我已经让它工作得很好了,但是现在每当线程试图访问套接字时,我就会得到“SocketException:Socket已关闭”

我和我的老师都搞不懂。(老师对Java的了解甚至比我还少;他是个C语言的家伙)。看起来套接字是打开的,但一旦进入线程,它就关闭了

我做错了什么

客户端代码:

public class Client {
    public static void main(String[] args) throws IOException {
        String hostName = "localhost";
        int portNumber = 6969;
        try (
                Socket socket = new Socket(hostName, portNumber);
        ) {
            System.out.println("Chat connected");
            //Sender
            if (!socket.isClosed())
                new Thread(new Sender(socket)).start();
            //Receiver
            if (!socket.isClosed())
                new Thread(new Receiver(socket)).start();
        } catch (SocketException e) {
            System.out.println("Connection terminated unexpectedly");
        }
    }
}
服务器代码:

public class Server {
    public static void main(String[] args) throws IOException {
        int portNumber = 6969;
        try (
                ServerSocket serverSocket = new ServerSocket(portNumber);
                Socket clientSocket = serverSocket.accept();
        ) {
            //Receiver
            if (!clientSocket.isClosed())
                new Thread(new Receiver(clientSocket)).start();
            //Sender
            if (!clientSocket.isClosed())
                new Thread(new Sender(clientSocket)).start();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}
接收器线程代码:

class Receiver implements Runnable {

    private Socket socket;

    Receiver(Socket s) throws IOException {
        socket = s;
    }

    @Override
    public void run() {
        try (BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()))) {
            String received;
            do {
                received = in.readLine();
                if (received == null) break;
                System.out.println("Them: " + received);
            } while (!received.contains("/dropmic"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
class Sender implements Runnable {
    private Socket socket;

    Sender(Socket s) throws IOException {
        socket = s;
    }

    @Override
    public void run() {
        try (PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
             BufferedReader stdIn = new BufferedReader(new InputStreamReader(System.in))) {
            String sent;
            do {
                System.out.print("You: ");
                sent = stdIn.readLine();
                if (sent == null) break;
                out.println(sent);
            } while (!sent.contains("/dropmic"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
发件人线程代码:

class Receiver implements Runnable {

    private Socket socket;

    Receiver(Socket s) throws IOException {
        socket = s;
    }

    @Override
    public void run() {
        try (BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream()))) {
            String received;
            do {
                received = in.readLine();
                if (received == null) break;
                System.out.println("Them: " + received);
            } while (!received.contains("/dropmic"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
class Sender implements Runnable {
    private Socket socket;

    Sender(Socket s) throws IOException {
        socket = s;
    }

    @Override
    public void run() {
        try (PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
             BufferedReader stdIn = new BufferedReader(new InputStreamReader(System.in))) {
            String sent;
            do {
                System.out.print("You: ");
                sent = stdIn.readLine();
                if (sent == null) break;
                out.println(sent);
            } while (!sent.contains("/dropmic"));
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}
服务器输出:

java.net.SocketException: Socket is closed
    at java.net.Socket.getOutputStream(Socket.java:943)
    at Sender.run(Sender.java:16)
    at java.lang.Thread.run(Thread.java:745)
java.net.SocketException: Socket closed
    at java.net.SocketInputStream.socketRead0(Native Method)
    at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
    at java.net.SocketInputStream.read(SocketInputStream.java:170)
    at java.net.SocketInputStream.read(SocketInputStream.java:141)
    at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:284)
    at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:326)
    at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:178)
    at java.io.InputStreamReader.read(InputStreamReader.java:184)
    at java.io.BufferedReader.fill(BufferedReader.java:161)
    at java.io.BufferedReader.readLine(BufferedReader.java:324)
    at java.io.BufferedReader.readLine(BufferedReader.java:389)
    at Receiver.run(Receiver.java:19)
    at java.lang.Thread.run(Thread.java:745)

Process finished with exit code 0
客户端输出(仍在运行):


您正在使用try with resources语句,并将套接字作为资源。但是,当您创建新线程时,此资源尝试到达其代码末尾并关闭套接字。将套接字放在实际的try语句中,并手动关闭它们以解决此问题。

您可以发布输出吗?是的,编辑了原始帖子