Многопоточный чат-сервер на Java - PullRequest
1 голос
/ 17 сентября 2009

Я пытаюсь реализовать программу сокет-сервер-клиент на Java, которая может поддерживать несколько клиентов, но мой класс, который выполняет многопоточность, всегда падает, когда мой клиент подключается к моему серверу.

import java.io.*;
import java.net.*;
public class ClientWorker extends Thread{
    Socket cwsocket=null;

    public ClientWorker(Socket cwsocket){
        super("ClientWorker");
        cwsocket=cwsocket;
    }

    public void run(){
        try {
            PrintWriter out = new PrintWriter(cwsocket.getOutputStream(), true);
            BufferedReader in = new BufferedReader(new InputStreamReader(cwsocket.getInputStream()));

            String serverinput, serveroutput="";

            out.println(serveroutput);

            while ((serverinput = in.readLine()) != null) {
                out.println(serveroutput);
                if (serveroutput.equals("Terminate"))
                    break;
            }
            out.close();
            in.close();
            cwsocket.close();

        } catch (IOException e) {
            e.printStackTrace();
        }   
    }
}

Всякий раз, когда я создаю объект PrintWriter, генерируется исключение NullPointerException, и я не уверен, почему это продолжает происходить. Ниже приведены мои серверные и клиентские классы. Что я делаю не так?

import java.io.*;
import java.net.*;
public class Server {

    public static void main(String[]args)throws IOException{
        ServerSocket serversocket=null;
        final int PORT_NUM=4444;
        boolean flag=true;
        try{
            System.out.println("Listening for connection");
            serversocket=new ServerSocket(PORT_NUM);
        }catch(IOException e){
            System.out.println("Could not listen to port: "+PORT_NUM);
            System.exit(-1);    
        }
        while(flag){
            new ClientWorker(serversocket.accept()).start();
        }
        System.out.println("Terminating server...");
        serversocket.close();
    }
}

import java.io.*;
import java.net.*;
public class Client {

    public static void main(String[] args){
        Socket socket=null;
        PrintWriter out=null;
        BufferedReader in=null;
        BufferedReader userInputStream=null;
        String IP="127.0.0.1";
        try{
            socket = new Socket(IP, 4444);
            out = new PrintWriter(socket.getOutputStream(), true);
            in = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        } catch (UnknownHostException e) {
            System.out.println("Unknown host:" + IP);
            System.exit(1);
        } catch  (IOException e) {
            System.out.println("Cannot connect to server...");
            System.exit(1);
        }
        String userInput, fromServer;
        try{        
            userInputStream = new BufferedReader(new InputStreamReader(System.in));
            while ((fromServer = in.readLine()) != null) {
                System.out.println("Server: " + fromServer);
                if (fromServer.equals("Terminate"))
                    break;

                userInput = userInputStream.readLine();
                if (userInput != null) {
                        System.out.println("> " + userInput);
                        out.println(userInput);
                }
            }
        }catch(IOException e){
            System.out.println("Bad I/O");
            System.exit(1);
        }
        try{
            out.close();
            in.close();
            userInputStream.close();
            socket.close();
            System.out.println("Terminating client...");
        }catch(IOException e){
            System.out.println("Bad I/O");
            System.exit(1);
        }catch(Exception e){
            System.out.println("Bad I/O");
            System.exit(1);
        }
    }
}

1 Ответ

9 голосов
/ 17 сентября 2009

В

    public ClientWorker(Socket cwsocket){
        super("ClientWorker");
        cwsocket=cwsocket;
    }

Вам нужно сделать

        this.cwsocket=cwsocket;

Или переименуйте параметр, чтобы он не скрывал члена с тем же именем.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...