Primeros pasos con android-asynctask

AsyncTask desde el concepto hasta la implementación

Concepto

AsyncTask es una clase que permite ejecutar operaciones en segundo plano y los resultados se publican en el subproceso de la interfaz de usuario. El objetivo principal es eliminar todo el código repetitivo para iniciar/ejecutar un subproceso mediante la eliminación de los controladores y todo lo que se necesita para manipular los subprocesos. Además, el propósito de AsyncTask es tener operaciones de corta duración en un subproceso en segundo plano (unos segundos como máximo), no operaciones de larga duración. Por lo tanto, es importante que AsyncTask no se confunda con un marco de subprocesamiento genérico. Si se necesitan operaciones de larga duración, se recomienda el paquete concurrente.

Consideraciones generales

AsyncTask se define por tres tipos genéricos: Params, Progress y Results. Desde el momento en que se ejecuta, pasa por 4 pasos (métodos). Primero está onPreExecute, donde alguien puede definir un cuadro de diálogo de carga o algún mensaje de interfaz de usuario que puede notificar al usuario que la ejecución está a punto de comenzar. A continuación, doInBackground, que es el método que se ejecuta de forma asíncrona en un subproceso diferente al subproceso Ui. El tercer método es onProgressUpdate, que también se puede ejecutar en el subproceso de la interfaz de usuario que puede notificar al usuario sobre el estado. El último método llamado es onPostExecute y se usa principalmente para publicar los resultados.

A continuación se muestra un ejemplo de cómo usar una AsyncTask, devolviendo una cadena.
Ejemplo 1

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button button = (FloatingActionButton) findViewById(R.id.btn);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                executeAsyncTaskOperation();
            }
        });
    }


      private void executeAsyncTaskOperation() {
        new CustomAsyncTask(this).execute();
    }

    private static class CustomAsyncTask extends AsyncTask<Void, Void, String> {

        private Context context;
        private ProgressDialog progressDialog;

        public CustomAsyncTask(Context context) {
            this.context = context;
        }

        @Override
        protected void onPreExecute() {
            progressDialog = ProgressDialog.show(context, "Please wait...", "Loading data from web");
        }

        @Override
        protected String doInBackground(Void... params) {
            String object = null;
            try {
                Log.d(CustomAsyncTask.class.getCanonicalName(), "doInBackground");
                Thread.sleep(500);
                //bject = "new object";
            } catch (Exception exc) {
                Log.e(CustomAsyncTask.class.getCanonicalName(), "exception");
                object = null;
            }
            return object;
        }

        @Override
        protected void onPostExecute(String s) {
            if (progressDialog != null && progressDialog.isShowing()) {
                progressDialog.dismiss();
            }
            if (s != null) {
                Toast.makeText(context, "finished successfully!", Toast.LENGTH_LONG).show();
            } else {
                Toast.makeText(context, "finished unsuccessfully!", Toast.LENGTH_LONG).show();

            }
        }
    }
}

Ejemplo 2

Aquí, AsyncTask es un poco diferente, el método de ejecución recibe una lista de datos para analizar en segundo plano. El resultado de la devolución depende de esta comprobación.

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
        fab.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                        .setAction("Action", null).show();

                executeAsyncTaskOperation();
            }
        });
    }


    private void executeAsyncTaskOperation() {
        Boolean[] bools = new Boolean[10];
        for (int k = 0; k < 10; k++) {
            if (k % 2 == 0) {
                bools[k] = true;
            } else {
                bools[k] = false;
            }
        }
        new CustomAsyncTask(this).execute(bools);
    }

    private static class CustomAsyncTask extends AsyncTask<Boolean, Void, Integer> {

        private Context context;
        private ProgressDialog progressDialog;

        public CustomAsyncTask(Context context) {
            this.context = context;
        }

        @Override
        protected void onPreExecute() {
            progressDialog = ProgressDialog.show(context, "Please wait...", "Loading data from web");
        }

        @Override
        protected Integer doInBackground(Boolean... params) {
            int count = 0;
            try {
                Thread.sleep(1000);
                Log.d(CustomAsyncTask.class.getCanonicalName(), "doInBackground");
                for (Boolean param : params) {
                    if (param) {
                        count++;
                    }
                }
            } catch (Exception exc) {
                Log.e(CustomAsyncTask.class.getCanonicalName(), "exception");
                count = 0;
            }
            return count;
        }

        @Override
        protected void onPostExecute(Integer s) {
            if (progressDialog != null && progressDialog.isShowing()) {
                progressDialog.dismiss();
            }
            if (s != null && s > 0) {
                Toast.makeText(context, "finished loading: " + s + " tasks", Toast.LENGTH_LONG).show();
            } else {
                Toast.makeText(context, "finished unsuccessfully!", Toast.LENGTH_LONG).show();

            }
        }
    }
}