Как предотвратить тайм-аут приложения? - PullRequest
3 голосов
/ 17 марта 2009

Я создал многопоточное приложение, но оно все еще зависает, если сервер недоступен.

В основной деятельности я создал следующие методы:

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    //bind GUI elements
    ...

    //start TCPConnection Service in a new thread
    establishTCPConnection();
    ...

}


private void establishTCPConnection(){
    TCPClientServiceThread = new Thread(null, backgroundConnection, "connection");
    TCPClientServiceThread.start();
}

..


private Runnable backgroundConnection = new Runnable(){
    public void run(){
        //establish TCP connection
        doEstablishTCPConnection();
    }
};

private void doEstablishTCPConnection()
{
    //start TCPConnection service
    startService(new Intent(this, TCPClientService.class));
}

А это класс TCPClientService:

public class TCPClientService extends Service{

...

private String serverAddress = "192.168.1.5";
private int portNumber = 1000;



@Override
public void onCreate()
{
    //TODO: Actions to perform when service is created
    connectionAvailable = false;

    IntentFilter dataReceiverFilter;
    dataReceiverFilter = new IntentFilter(MotranetClient.MOTION_DATA_UPDATED);
    dataReceiver = new DataReceiver();
    registerReceiver(dataReceiver, dataReceiverFilter);

    EstablishConnection();
}

@Override
public IBinder onBind(Intent intent)
{
    //TODO: Replace with service binding implementation
    return null;
}

private void EstablishConnection()
{
    try {
           InetAddress serverAddr = InetAddress.getByName(serverAddress);
           Log.d("TCP", "C: Connecting...");
           Socket socket = new Socket(serverAddr, portNumber);
           String message = "testing connection";

               try {
                Log.d("TCP", "C: Sending: '" + message + "'");
                PrintWriter out = new PrintWriter( new BufferedWriter( new OutputStreamWriter(socket.getOutputStream())),true);
                out.println(message);
                Log.d("TCP", "C: Sent.");
                  Log.d("TCP", "C: Done.");
                  connectionAvailable = true;

             } catch(Exception e) {
                 Log.e("TCP", "S: Error", e);
                 connectionAvailable = false;

               } finally {
                  socket.close();
                  announceNetworkAvailability(connectionAvailable);
                }

         } catch (Exception e) {
              Log.e("TCP", "C: Error", e);
              announceNetworkAvailability(connectionAvailable);
         }
    }


}

Когда сервер недоступен, строка

Socket socket = new Socket(serverAddr, portNumber);

вызывает некоторую задержку, и я считаю, что это повод для зависания. Но если служба TCPClientService выполняется в своем собственном потоке, я не знаю, почему это влияет на время ожидания основного действия.

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

1 Ответ

2 голосов
/ 18 марта 2009

Платформа Android - всегда - запускает методы жизненного цикла для действий и служб в главном потоке событий. Таким образом, вы создаете другой поток и вызываете из него startService ... но когда служба создается и запускается, методы onCreate () и т. Д. Вызываются из основного потока событий, а не из вашего пользовательского потока.

Правильный способ сделать это - не вызывать startService из другого потока, а вызывать startService обычным образом, а затем Service вызывать поток соединения из onCreate ().

Решение ssakl не решает основную проблему, я боюсь.

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