I made a Java messaging app in Eclipse that runs fine as a JAR...now I am trying to make the same app using Android Studio in order to learn about basic android development...i don't understand why i get the error message "ChatAppAndroidClone keeps stopping".
in logCat it says:
2021-05-19 11:57:05.907 25336-25362/com.jasonkadams.chatappandroidclone E/AndroidRuntime: FATAL EXCEPTION: Thread-2 Process: com.jasonkadams.chatappandroidclone, PID: 25336 java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.io.BufferedReader.readLine()' on a null object reference at com.jasonkadams.chatappandroidclone.MainActivity$IncomingReader.run(MainActivity.java:99) at java.lang.Thread.run(Thread.java:764)
Does anyone know why this might be happening? Thanks in advance
Here is my java code (just one class):
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.Socket;
public class MainActivity extends AppCompatActivity {
    BufferedReader reader;
    PrintWriter writer;
    Socket sock;
    //String userName = System.getProperty("user.name");
    String emoji = "8===D";
    Button btn_send,btn_emoji;
    EditText outgoing;
    TextView incoming;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn_send=findViewById(R.id.btn_send);
        btn_emoji=findViewById(R.id.btn_emoji);
        outgoing=findViewById(R.id.outgoing);
        incoming=findViewById(R.id.incoming);
        //set up networking and thread for incoming messages
        setUpNetworking();
        Thread readerThread = new Thread(new IncomingReader());
        readerThread.start();
        //BUTTONS//
        btn_send.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                // if (outgoing.getText() != null)
                try {
                    writer.println("userName" + ": "+outgoing.getText().toString());
                    writer.flush();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
                outgoing.setText("");
                outgoing.requestFocus();
            }
        });
        btn_emoji.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                try {
                    writer.println("userName" + ": "+emoji);
                    writer.flush();
                } catch (Exception ex) {
                    ex.printStackTrace();
                }
            }
        });
    }
    //METHODS//
    private void setUpNetworking() {
        try {
            sock = new Socket("10.0.0.171", 5000);
            InputStreamReader streamReader = new InputStreamReader(sock.getInputStream());
            reader = new BufferedReader(streamReader);
            writer = new PrintWriter(sock.getOutputStream());
            System.out.println("Server connection established.");
            incoming.append("Server connection established." + "\n");
        } catch (IOException ex) {
            ex.printStackTrace();
            System.out.println("Server connection failed.");
            incoming.append("Server connection failed." + "\n");
        }
    }
    // displays messages
    class IncomingReader implements Runnable {
        public void run() {
            String message;
            try {
                while ((message = reader.readLine()) != null) {
                    System.out.println("client read " + message);
                    incoming.append(message+"\n");
                }
            } catch (IOException ex) {
                ex.printStackTrace();
            }
        }
    }
}
 
    