AsyncTask的execute并没有立即执行

        百度下,也是有不少方案和AsyncTask原理讲解的,匆匆忙忙地找了,实践有效,也没时间看下原理(看了也记不太清楚),在此做下记录。

原因不讲了,也讲不清楚,解决方案就是利用executeOnExecutor设置自己的队列,从而在旧页面关闭前能及时清理当前页面发出的数据请求;

Ps:tasks为一个ArrayList,用来存储当前界面所有产生的task,executeOnExecutor能清除等待中的task们,cancle(true)能防止再次快速进入同一页面时,前一次正在执行的请求数据的干扰。

//线程管理
LinkedBlockingQueue<Runnable> blockingQueue = new LinkedBlockingQueue<Runnable>();
ExecutorService exec = new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, blockingQueue);
public void startTask()
{
   MyTask myTask=new MyTask();
   tasks.add(myTask);
   if(Build.VERSION.SDK_INT>=Build.VERSION_CODES.HONEYCOMB)
   {
      myTask.executeOnExecutor(exec);
   }
   else
   {
      myTask.execute();
   }

}
//及时销毁
protected void onDestroy() {
   if (blockingQueue != null) {
      blockingQueue.clear();
   }
   if(tasks!=null)
   {
      Log.d("dy", "task:" + tasks.size());
      for(AsyncTask task:tasks)
      {
         task.cancel(true);
      }
   }
}

猜你喜欢

转载自blog.csdn.net/Dyan_csdn/article/details/51329303