<br />
AsyncTask是并行执行的吗?一般都会觉得当然是并行执行,但其实不是。
在Android 1.5刚引入的时候,AsyncTask的execute
是串行执行的;到了Android 1.6直到Android 2.3.2,又被修改为并行执行了,这个执行任务的线程池就是THREAD_POOL_EXECUTOR
,因此在一个进程内,所有的AsyncTask都是并行执行的;但是在Android 3.0以后,如果你使用execute
函数直接执行AsyncTask,那么这些任务是串行执行的。
public static final Executor SERIAL_EXECUTOR = new SerialExecutor();
private static volatile Executor sDefaultExecutor = SERIAL_EXECUTOR;
/**
* An {@link Executor} that executes tasks one at a time in serial
* order. This serialization is global to a particular process.
*/
public final AsyncTask<Params, Progress, Result> execute(Params... params) {
return executeOnExecutor(sDefaultExecutor, params);
}
因此结论就来了:Android 3.0以上,AsyncTask默认并不是并行执行的。
<br />
为什么默认不并行执行?
<br />
也许你不理解,为什么AsyncTask默认把它设计为串行执行的呢?
由于一个进程内所有的AsyncTask都是使用同一个线程池执行任务,如果同时有几个AsyncTask一起并行执行的话,恰好AysncTask的使用者在doInbackgroud
里面访问了相同的资源,但是自己没有处理同步问题;那么就有可能导致灾难性的后果!
由于开发者通常不会意识到需要对他们创建的所有的AsyncTask对象里面的doInbackgroud
做同步处理,因此,API的设计者为了避免这种无意中访问并发资源的问题,干脆把这个API设置为默认所有串行执行的了。
<br />
如何让AsyncTask并行执行?
<br />
如果你确定自己做好了同步处理,或者你没有在不同的AsyncTask里面访问共享资源,需要AsyncTask能够并行处理任务的话,你可以用带有两个参数的executeOnExecutor
执行任务:
new AsyncTask<Void, Void, Void>(){
@Override
protected Void doInBackground(Void... params) {
return null;
}
}.executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR);