Я получаю силу близко, когда я начинаю новую тему! - PullRequest
1 голос
/ 16 апреля 2011

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

Моя проблема в том, что когдаЯ запускаю эту новую тему. Я не знаю, что происходит, но когда я пытаюсь взаимодействовать с моим графическим интерфейсом (нажмите кнопку, которая переводит меня в другое занятие), меня закрывают силой.

Это немного запутанная причина, так какЯ читаю на разных веб-страницах, что новая ветка, которую я запускаю, не имеет ничего общего с моим графическим интерфейсом, поэтому даже если клиент попытается подключиться или не сможет подключиться, я смогу «поиграть» с моим интерфейсом.

Вот мой код:

public class screen1 extends Activity {

private TextView clientState;
private String serverIpAddress="10.0.2.2";
public static final int ClientPort = 8080;
String message="Hello Server!";
int longitude;
int latitude;
private PrintWriter out=null;
DBAdapter db;
private Handler handler=new Handler();
Socket socket;
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.screen1);
    clientState = (TextView) findViewById(R.id.client_Status);

// это кнопка, предназначенная для перехода к другому виду деятельности, и при нажатии она дает мне FC

    Button b = (Button)findViewById(R.id.mainMenu);
    b.setOnClickListener(new View.OnClickListener() {
       public void onClick(View arg0) {
       Intent i = new Intent(screen1.this, screen2.class);
       startActivity(i);
       } 
    });

// здесь я запускаю новую тему, определенную ниже

  Thread cThread=new Thread(new ClientThread()); 

  cThread.start();  
db=new DBAdapter(this);

}

// здесь мой клиент пытается подключиться

public class ClientThread implements Runnable{


    public void run()
    {
        try
        {
            InetAddress serverAddr=InetAddress.getByName(serverIpAddress);
            handler.post(new Runnable(){
                public void run(){
                    clientState.setText(" try to connect!");
                }
            });
            socket=new Socket(serverAddr,ClientPort);

            //connected=true;
        handler.post(new Runnable(){
                public void run(){
                    clientState.setText("Connected!");
                }
            });

        PrintWriter out=new PrintWriter(socket.getOutputStream(),true);
        db.createDatabase();
         db.openDataBase();
           Cursor c=db.getAllData();

           if(c.moveToFirst()) 
             {
              do{

                  longitude=Integer.parseInt(c.getString(1));
                  out.println(longitude);
                  latitude=Integer.parseInt(c.getString(2));
                  out.println(latitude);

              }while(c.moveToNext());

             }




        }
        catch(Exception e){
            handler.post(new Runnable(){
                public void run(){
                    clientState.setText("Error");
                    }
            });

            e.printStackTrace();
        }

    }

}

И метод onStop ():

protected void onStop() {

 super.onStop();

  try {

        out.close();
        socket.close();

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

Ну, вот оно, длядальнейшие детали я здесь, чтобы объяснить. Спасибо в Advance:)

0

4-16 03:51:25.045: ERROR/AndroidRuntime(242): Uncaught handler: thread main exiting due to uncaught exception

04-16 03:51:25.074: ERROR/AndroidRuntime(242): java.lang.RuntimeException: Unable to stop activity {test.android/test.android.screen1}: java.lang.NullPointerException

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread.performStopActivityInner(ActivityThread.java:3227)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread.handleStopActivity(ActivityThread.java:3272)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread.access$2500(ActivityThread.java:119)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1880)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.os.Handler.dispatchMessage(Handler.java:99)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.os.Looper.loop(Looper.java:123)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread.main(ActivityThread.java:4363)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at java.lang.reflect.Method.invokeNative(Native Method)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at java.lang.reflect.Method.invoke(Method.java:521)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at dalvik.system.NativeStart.main(Native Method)

04-16 03:51:25.074: ERROR/AndroidRuntime(242): Caused by: java.lang.NullPointerException

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at 
test.android.screen1.onStop(screen1.java:106)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at 
android.app.Instrumentation.callActivityOnStop(Instrumentation.java:1169)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.Activity.performStop(Activity.java:3797)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     at android.app.ActivityThread.performStopActivityInner(ActivityThread.java:3224)

04-16 03:51:25.074: ERROR/AndroidRuntime(242):     ... 11 more

04-16 03:51:25.144: INFO/Process(51): Sending signal. PID: 242 SIG: 3

04-16 03:51:25.154: INFO/dalvikvm(242): threadid=7: reacting to signal 3

04-16 03:51:25.204: INFO/dalvikvm(242): Wrote stack trace to '/data/anr/traces.txt'

04-16 03:51:41.604: INFO/Process(242): Sending signal. PID: 242 SIG: 9

04-16 03:51:41.714: INFO/ActivityManager(51): Process test.android (pid 242) has died.

04-16 03:51:41.753: INFO/WindowManager(51): WIN DEATH: Window{43e0eb10 test.android/test.android.screen2 paused=false}

04-16 03:51:41.765: INFO/WindowManager(51): WIN DEATH: Window{43e068b0 test.android/test.android.screen1 paused=false}

04-16 03:51:41.974: INFO/ActivityManager(51): Start proc test.android for activity test.android/.screen1: pid=249 uid=10030 gids={3003}

04-16 03:51:42.433: DEBUG/ddm-heap(249): Got feature list request

04-16 03:51:42.704: INFO/UsageStats(51): Unexpected resume of test.android while already resumed in test.android

04-16 03:51:43.294: WARN/InputManagerService(51): Got RemoteException sending setActive(false) notification to pid 242 uid 10030

04-16 03:51:43.513: INFO/ActivityManager(51): Displayed activity test.android/.screen1: 1736 ms (total 1736 ms)

Ну, дорогие друзья, я удалил из своего кода функцию onStop (), и все, кажется, работает!

protected void onStop() {

    super.onStop();

    try {

        out.close();


        socket.close();

     } catch (IOException e) {

         e.printStackTrace();

     }
}

Что с ним не так?: - S

1 Ответ

2 голосов
/ 16 апреля 2011

Я предполагаю, что переменная out в вашем onStop методе потока равна null.Вы объявляете переменную, но инициализируете ее с null и никогда не инициализируете ей другое значение.

Вы делаете

PrintWriter out=new PrintWriter(socket.getOutputStream(),true);

в методе run вашего потока, но этопеременная имеет область действия, отличную от переменной, используемой в вашем методе onStop.Вот почему вы получаете NullPointerException.

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