百度下,也是有不少方案和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); } }}