I'm trying to run them two AsyncTask sequences and does not work, it only runs the first. If I change the order of the AsyncTask, as only runs the first, the second is not, then the TimerTask if running. Look at my code: (Excuse my language, I speak Spanish.)
public class ServicioPrincipal extends Service
{ ...
public int onStartCommand(Intent intent, int flags, int startId)
{
new ServerAsyncTask().execute(serverSocket, getApplicationContext());
new ClientEspejoAsyncTask().execute(getApplicationContext());
timerTask = new TimerTask()
{
@Override
public void run()
{
//Log.i(TAG, "Ejecutando la tarea del servicio");
Utilitario.escribirLog("ServicioPrincipal: iniciarServicioPrincipal: timer is running...");
}
};
try
{
timer.scheduleAtFixedRate(timerTask, 0, 30000); //, 0, 15000);
}
catch(Exception ex)
{
Utilitario.escribirLog("ServicioPrincipal: iniciarServicioPrincipal: catch:"+ex.getMessage());
}
}
...
}
My classes:
private class ServerAsyncTask extends AsyncTask<Object, Void, String>
{
@Override
protected String doInBackground(Object... objs)
{
try
{
Utilitario.escribirLog("ServicioPrincipal: ServerAsyncTask: doInBackground");
server = new Server((ServerSocket)objs[0], (Context)objs[1]);
server.iniciarServer();
return "1";
}
catch (Exception e)
{
Utilitario.escribirLog("ServicioPrincipal: ServerAsyncTask: doInBackground: catch:"+e.getMessage());
return "0";
}
}
// onPostExecute displays the results of the AsyncTask.
@Override
protected void onPostExecute(String result)
{
Utilitario.escribirLog("ServicioPrincipal: ServerAsyncTask: onPostExecute-"+result);
pararServicioPrinipal();
}
}
private class ClientEspejoAsyncTask extends AsyncTask<Object, Void, String>
{
@Override
protected String doInBackground(Object... objs)
{
// params comes from the execute() call: params[0] is the url.
try
{
Utilitario.escribirLog("ServicioPrincipal: ClientEspejoAsyncTask: doInBackground");
clientEspejo = new ClientEspejo((Context)objs[0]);
clientEspejo.iniciarClientEspejo();
return "1";
}
catch (Exception e)
{
Utilitario.escribirLog("ServicioPrincipal: ClientEspejoAsyncTask: doInBackground: catch:"+e.getMessage());
return "0";
}
}
// onPostExecute displays the results of the AsyncTask.
@Override
protected void onPostExecute(String result)
{
Utilitario.escribirLog("ServicioPrincipal: ClientEspejoAsyncTask: onPostExecute-"+result);
pararServicioPrinipal();
}
}
thank you very much in advance.