AsyncTask的三个属性值和四个步骤
最近学到用asynctask来处理有关网络的操作。虽然代码看上去不是很复杂,但仍有很多地方有疑惑。所以研读了一下api文档,在这里把我学到的和练习的代码展示出来。如有错误,欢迎指出!
一、关于asynctask的<params, progress, result>
在创建asynctask的子类时,必须给出这三个具体的类型值,尖括号是泛型的意思。我不太理解api文档的解释,但往下看
doinbackground(params...)
publishprogress(progress...)
onprogressupdate(progress...)
onpostexecute(result)
可以知道它们都是传递给谁的,而圆括号里有...的参数可以理解为数组。
二、asynctask的四个步骤
1、onpreexecute():这个方法是在任务开始前进行的,它由ui线程(主线程)调用,即可以进行ui操作。在最后,我会给出log的打印信息。
2、doinbackground(params...):这个方法是onpreexecute()完成后,立即在后台进行的,用以执行任务,并将result传给onpostexecute(result)。另外,在此期间,可以调用publishprogress(progress...),这个方法能够传递一些数据给onprogressupdate(progress...)。
3、onprogressupdate(progress...):在publishprogress(progress...)被调用之后,此方法会由ui线程调用。所以利用publishprogress(progress...)和onprogressupdate(progress...)就能够做出在加载或读取网络数据时的等待或缓冲的ui效果。我在最后给出的效果图有类似的功能。
4、onpostexecute(result):在doinbackground(params...)完成后,由ui线程调用,在这里处理result。
三、我练习时写的代码
这是启动任务,这里的execute(),可以传进多个参数,如execute(url1,url2,url3)
然后在doinbackground中就可以处理多个任务,publishprogress和onprogressupdate也类似
四、最终效果图
在确认前,该textview是空的,在确认后,获取的信息加载出来前,该textview是显示loading的,可能gif做得不好,看上去有点怪。另外,在正常情况下,loading是一闪而过的。我这里是断点调试时,截图做的。
最后是上面介绍的四个方法的log信息
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!