Android实现图片异步请求加三级缓存

2019-12-10 19:05:45于海丽
这篇文章主要向大家详细介绍了Android实现图片异步请求加三级缓存的相关资料,需要的朋友可以参考下  

使用xUtils等框架是很方便,但今天要用代码实现bitmapUtils 的功能,很简单,

AsyncTask请求一张图片

####AsyncTask

#####AsyncTask是线程池+handler的封装 第一个泛型: 传参的参数类型类型(和doInBackground一致) 第二个泛型:
#####更新进度的参数类型(和onProgressUpdate一致) 第三个泛型: 返回结果的参数类型(和onPostExecute一致,
#####和doInBackground返回类型一致)

看AsyncTask源码:

public abstract class AsyncTask<Params, Progress, Result> {
 private static final String LOG_TAG = "AsyncTask";

 private static final int CORE_POOL_SIZE = 5;
 private static final int MAXIMUM_POOL_SIZE = 128;
 private static final int KEEP_ALIVE = 1;

 private static final ThreadFactory sThreadFactory = new ThreadFactory() {
  private final AtomicInteger mCount = new AtomicInteger(1);

  public Thread newThread(Runnable r) {
   return new Thread(r, "AsyncTask #" + mCount.getAndIncrement());
  }
 };


核心线程5 最大线程128  这是AsyncTask的线程池  然后通过handler发送消息 , 它内部实例化了一个静态的自定义类 InternalHandler,这个类是继承自 Handler 的,在这个自定义类中绑定了一个叫做 AsyncTaskResult 的对象,每次子线程需要通知主线程,就调用 sendToTarget 发送消息给 handler自己。然后在 handler 的 handleMessage 中 AsyncTaskResult 根据消息的类型不同(例如 MESSAGE_POST_PROGRESS 会更新进度条,MESSAGE_POST_CANCEL 取消任务)而做不同的操作,值得一提的是,这些操作都是在UI线程进行的,意味着,从子线程一旦需要和 UI 线程交互,内部自动调用了 handler 对象把消息放在了主线程了。

 private static final InternalHandler sHandler = new InternalHandler();

 mFuture = new FutureTask<Result>(mWorker) {
   @Override
   protected void More ...done() {
    Message message;
    Result result = null;
    try {
     result = get();
    } catch (InterruptedException e) {
     android.util.Log.w(LOG_TAG, e);
    } catch (ExecutionException e) {
     throw new RuntimeException("An error occured while executing doInBackground()",
       e.getCause());
    } catch (CancellationException e) {
     message = sHandler.obtainMessage(MESSAGE_POST_CANCEL,
       new AsyncTaskResult<Result>(AsyncTask.this, (Result[]) null));
     message.sendToTarget();
     return;
    } catch (Throwable t) {
     throw new RuntimeException("An error occured while executing "
       + "doInBackground()", t);
    }

    message = sHandler.obtainMessage(MESSAGE_POST_RESULT,
      new AsyncTaskResult<Result>(AsyncTask.this, result));
    message.sendToTarget();
   }
  };
 private static class InternalHandler extends Handler {
  @SuppressWarnings({"unchecked", "RawUseOfParameterizedType"})
  @Override
  public void More ...handleMessage(Message msg) {
   AsyncTaskResult result = (AsyncTaskResult) msg.obj;
   switch (msg.what) {
    case MESSAGE_POST_RESULT:
     // There is only one result
     result.mTask.finish(result.mData[0]);
     break;
    case MESSAGE_POST_PROGRESS:
     result.mTask.onProgressUpdate(result.mData);
     break;
    case MESSAGE_POST_CANCEL:
     result.mTask.onCancelled();
     break;
   }
  }
 }