基本可以认为是在executor和futureTask上加了一个封装。用一个队列存放task,使用executor执行。
0. 1.6以后使用线程池技术,3.0以后每个task都在同一个thread中运行
1.使用atomic包作为计数工具
2.使用handler做的回调(onPostExecute.onProgressUpdate)
3.使用ArrayDeque做任务队列,稍后看ArrayDeque的源码
4.每次都将正在执行的任务放到队列外,保证无需加锁
这个结构应该跟JS的执行模式很像,所以,前面的任务对后面的执行是有影响的,所以要小心,要真正的并行还是自己做吧。内部的设置线程池功能被hide了。