The AsyncTask
class can be thought of as a very convenient threading mechanism. It gives you a few tools that you can use that simple Java threads simply don't have such as on cancel cleanup operations. You don't have to do any UI in the background. You could simply execute one by writing one as an anonymous class like this:
new AsyncTask<Integer, Void, Void>(){
@Override
protected Void doInBackground(Integer... params) {
// **Code**
return null;
}
}.execute(1, 2, 3, 4, 5);
It will execute whatever you put in doInBackground
on a background thread with the given parameters. Likewise, you can simply use Void
and execute with no parameters.
The only advantage I could think of executing a thread this way would be to aid in future maintenance. There might be a case where you want to modify certain things that are required to be on the UI thread, in which case you would override the other methods. Other cases would be you simply don't do the action enough to justify writing out another class, so just create one on the fly and be done with it.
EDIT:
To answer #3: they're effectively the same. The Void
object is a Java object just like anything else. You're not using Void
, so what you use in it's place doesn't matter. It's just the AsyncTask
contract requires three class types to be passed in, and by default they're Object
which is the baseline class of everything.
与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…