AsyncTask源码

来源:互联网 发布:db2关闭数据库 编辑:程序博客网 时间:2024/06/05 02:27

基本可以认为是在executor和futureTask上加了一个封装。用一个队列存放task,使用executor执行。

0. 1.6以后使用线程池技术,3.0以后每个task都在同一个thread中运行

1.使用atomic包作为计数工具

2.使用handler做的回调(onPostExecute.onProgressUpdate

3.使用ArrayDeque做任务队列,稍后看ArrayDeque的源码

4.每次都将正在执行的任务放到队列外,保证无需加锁


这个结构应该跟JS的执行模式很像,所以,前面的任务对后面的执行是有影响的,所以要小心,要真正的并行还是自己做吧。内部的设置线程池功能被hide了。

0 0
原创粉丝点击