原理简述:
AsyncTask内部持有一个2~4线程大小的线程池,当执行asynctask的execute(Runnable)方法时会将任务提交到内部的ArrayDeque的任务容器内,并执行SerialExecutor的execute方法,从arraydeque里取出任务并串行执行
当执行execute(params...)方法时会执行executeonexecutor,此时的执行是并行的,任务会被封装成一个WorkerRunnable,WorkerRunnable内部持有一个params数组,并被最终封装成了FutureTask来进行处理,由内部线程池来进行处理,携带的参数会在doinBackground时进行处理中回调,此回调会在子线程回调,处理完成后会通过postResult来进行结果通知。postResult里会获取由创建Asynctask时候传递的handler来处理,不传handler默认在主线程,传了handler则在handler传入的线程进行postResult回调。