android AsyncTask相关的一些面试题目
AsyncTask在android4.0之后android采用线程池来实现,最多开5个线程,所以几个AsyncTask执行的时候顺序是随机的,
如果5个AsyncTask顺序执行之后,又有一个AsyncTask,那最后一个会被挂起,当5个AsyncTask有一个被执行完以后最后一个会被插入执行
public class TestActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.test); new fetchServerVersionAndSupportOsHttpTasker().execute(); new fetchServerVersionAndSupportOsHttpTasker1().execute(); new fetchServerVersionAndSupportOsHttpTaske2().execute(); } public class fetchServerVersionAndSupportOsHttpTasker extends AsyncTask<Object, Integer, String> { @Override protected String doInBackground(Object... params) { System.out.println("=============first doInBackground"); CommonHttpRequest.getForceUpgradeRelatedInfo(); return "aaaa"; } @Override protected void onPostExecute(String result) { if(!TextUtils.isEmpty(result)) { System.out.println("===============first postexecute"); } } } public class fetchServerVersionAndSupportOsHttpTasker1 extends AsyncTask<Object, Integer, String> { @Override protected String doInBackground(Object... params) { System.out.println("=============second doInBackground"); CommonHttpRequest.getForceUpgradeRelatedInfo(); return "bbb"; } @Override protected void onPostExecute(String result) { if(!TextUtils.isEmpty(result)) { System.out.println("===============second postexecute"); } } } public class fetchServerVersionAndSupportOsHttpTaske2 extends AsyncTask<Object, Integer, String> { @Override protected String doInBackground(Object... params) { System.out.println("=============third doInBackground"); //CommonHttpRequest.getForceUpgradeRelatedInfo(); return "ccc"; } @Override protected void onPostExecute(String result) { if(!TextUtils.isEmpty(result)) { System.out.println("===============third postexecute"); } } } }执行结果:
10-16 14:03:38.872: I/System.out(23132): =============third doInBackground 10-16 14:03:38.872: I/System.out(23132): =============second doInBackground 10-16 14:03:38.872: I/System.out(23132): =============first doInBackground 10-16 14:03:38.892: I/System.out(23132): ===============third postexecute 10-16 14:03:38.922: I/System.out(23132): ===============second postexecute 10-16 14:03:38.922: I/System.out(23132): ===============first postexecute
堆栈就是这样一种数据结构。它是在内存中开辟一个存储区域,数据一个一个顺序地存入(也就是“压入——push”)这个区域之中。有一个地址指针总指向最后一个压入堆栈的数据所在的数据单元,存放这个地址指针的寄存器就叫做堆栈指示器。开始放入数据的单元叫做“栈底”。数据一个一个地存入,这个过程叫做“压栈”。在压栈的过程中,每有一个数据压入堆栈,就放在和前一个单元相连的后面一个单元中,堆栈指示器中的地址自动加1。读取这些数据时,按照堆栈指示器中的地址读取数据,堆栈指示器中的地址数自动减 1。这个过程叫做“弹出pop”。如此就实现了后进先出的原则。
TASK1包含三个activity分别是:p,q,r;启动顺序为p-->q-->r TASK2包含两个activity分别是:a,b;启动顺序为a-->b; TASK1首先启动p,那么这个p就是执行这个任务的根activity,任务也是定义在这个activity下的。通过属性Manifest文件中的activity属性中的taskAffinity来定义。 (1)此时p启动后就被压入堆栈,因为此时堆栈中只有这一个activity,所以p处于栈底,也处于栈顶。此时用户能够看到的就是p界面。 (2)p启动q后,q入栈。此时栈顶为q。q呈现的界面将p覆盖,p进入后台运行(此时是activity生命周期的pause状态)或者进入后台但不运行(此时是activity生命周期的stop状态)。 (3)q启动r后,r入栈。此时栈顶为r。r呈现的界面将q覆盖,q进入后台运行。 (4)按back键后就是调用finish函数结束r (activity)的生命。此时r出栈,r的生命周期结束。 (5)继续back键,结束q的生命,此时q出栈。 (6)继续back键,结束p的生命,此时p出栈。 (7)此时栈内所有activity都已出栈,所以就会显示HOME屏幕界面.
如果A->B->C->C如果C是singleTop或是singletask那么最后一次C不会执行oncreate
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。