Glide源码解读之绑定生命周期

今天有空,稍微解读了一下glide加载图片框架源码,glide源码比较多,除了弄清楚主流程,对我编程有帮助的,我都会记录下来。

我这里不会一步一步详细解读源码,因为其他博客一大堆,我这里主要讲解一下原理;

绑定生命周期,不用我们自己在onStart,onStop去调用,这种思想很好,所以,值得借鉴。

主要实现原理是创建一个无UI的Fragment添加(绑定)到当前的Activity(或其他Fragment),通过重写Fragment的onStart和onStop方法,通知RequestManager任务改变状态。

源码如下:

外观类:RequestManagerRetriever

package com.johan.glide;

import android.os.Handler;
import android.os.Looper;
import android.os.Message;

import androidx.annotation.NonNull;
import androidx.fragment.app.Fragment;
import androidx.fragment.app.FragmentActivity;
import androidx.fragment.app.FragmentManager;

import java.util.HashMap;
import java.util.Map;

public class RequestManagerRetriever implements Handler.Callback {

    private static RequestManagerRetriever instance;

    public static RequestManagerRetriever getInstance() {
        if (instance == null) {
            synchronized (RequestManagerRetriever.class) {
                if (instance == null) {
                    instance = new RequestManagerRetriever();
                }
            }
        }
        return instance;
    }

    private Map<FragmentManager, RequestManagerFragment> tempMap;
    private Handler handler;

    public RequestManagerRetriever() {
        tempMap = new HashMap<>();
        handler = new Handler(Looper.getMainLooper(), this);
    }

    public RequestManager getRequestManager(FragmentActivity fragmentActivity) {
        return getRequestManager(fragmentActivity.getSupportFragmentManager());
    }

    public RequestManager getRequestManager(Fragment fragment) {
        return getRequestManager(fragment.getChildFragmentManager());
    }

    private RequestManager getRequestManager(FragmentManager fragmentManager) {
        // 从 FragmentManager 通过 tag 获取 Fragment
        RequestManagerFragment managerFragment = (RequestManagerFragment) fragmentManager.findFragmentByTag("com.johan.glide");
        if (managerFragment == null) {
            // 从临时缓存获取 Fragment
            // 为什么要用到临时缓存呢?
            // 比如连续两次调用 getRequestManager 方法
            // 因为 fragmentManager.beginTransaction().add(managerFragment, "com.johan.glide").commitAllowingStateLoss(); 这句代码执行之后呢
            // 创建的 Fragment 不会马上能被 fragmentManager.findFragmentByTag("com.johan.glide") 找到
            // 防止重复添加到 FragmentManager
            managerFragment = tempMap.get(fragmentManager);
            if (managerFragment == null) {
                // 创建
                managerFragment = new RequestManagerFragment();
                // 加入临时缓存
                tempMap.put(fragmentManager, managerFragment);
                // 添加到 FragmentManager
                fragmentManager.beginTransaction().add(managerFragment, "com.johan.glide").commitAllowingStateLoss();
                // 通知移除临时缓存
                handler.obtainMessage(0, fragmentManager).sendToTarget();
            }
        }
        // 先从 RequestManagerFragment 获取 RequestManager
        RequestManager manager = managerFragment.getRequestManager();
        if (manager == null) {
            // 创建
            manager = new RequestManager(managerFragment.getActivityLifeCycle());
            // 设置
            managerFragment.setRequestManager(manager);
        }
        return manager;
    }

    @Override
    public boolean handleMessage(@NonNull Message message) {
        //  移除临时缓存
        tempMap.remove((FragmentManager) message.obj);
        return true;
    }

}

无 UI Fragment:RequestManagerFragment

package com.johan.glide;

import android.util.Log;

import androidx.fragment.app.Fragment;

public class RequestManagerFragment extends Fragment {

    private ActivityLifeCycle activityLifeCycle;
    private RequestManager requestManager;

    public RequestManagerFragment() {
        activityLifeCycle = new ActivityLifeCycle();
    }

    public ActivityLifeCycle getActivityLifeCycle() {
        return activityLifeCycle;
    }

    public void setRequestManager(RequestManager requestManager) {
        this.requestManager = requestManager;
    }

    public RequestManager getRequestManager() {
        return requestManager;
    }

    @Override
    public void onStart() {
        super.onStart();
        Log.e("glide", "RequestManagerFragment onStart --------- ");
        // 生命周期回调
        if (activityLifeCycle != null) {
            activityLifeCycle.onStart();
        }
    }

    @Override
    public void onStop() {
        super.onStop();
        Log.e("glide", "RequestManagerFragment onStop --------- ");
        // 生命周期回调
        if (activityLifeCycle != null) {
            activityLifeCycle.onStop();
        }
    }

}

生命周期监听接口:LifeCycleListener

public interface LifeCycleListener {

    void onStart();

    void onStop();

}

生命周期接听接口管理者:ActivityLifeCycle

package com.johan.glide;

import java.util.ArrayList;
import java.util.List;

public class ActivityLifeCycle implements LifeCycleListener {

    private List<LifeCycleListener> lifeCycleListeners;

    public ActivityLifeCycle() {
        lifeCycleListeners = new ArrayList<>();
    }

    public void addLifeCycleListener(LifeCycleListener lifeCycleListener) {
        lifeCycleListeners.add(lifeCycleListener);
    }

    public void removeLifeCycleListener(LifeCycleListener lifeCycleListener) {
        lifeCycleListeners.remove(lifeCycleListener);
    }

    @Override
    public void onStart() {
        for (LifeCycleListener lifeCycleListener : lifeCycleListeners) {
            lifeCycleListener.onStart();
        }
    }

    @Override
    public void onStop() {
        for (LifeCycleListener lifeCycleListener : lifeCycleListeners) {
            lifeCycleListener.onStop();
        }
    }

}

任务管理者:RequestManager

package com.johan.glide;

import android.util.Log;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class RequestManager implements LifeCycleListener {

    private ExecutorService executorService;
    private Future future;

    public RequestManager(ActivityLifeCycle activityLifeCycle) {
        executorService = Executors.newCachedThreadPool();
        // 监听生命周期
        activityLifeCycle.addLifeCycleListener(this);
    }

    /**
     * 模拟耗时操作
     */
    public void execute() {
        future = executorService.submit(new Runnable() {
            @Override
            public void run() {
                try {
                    for (int i = 0; i < 100; i++) {
                        Log.e("glide", this + " execute " + i);
                        Thread.sleep(1000);
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
    }

    @Override
    public void onStart() {
        Log.e("glide", "request start --------------");
    }

    @Override
    public void onStop() {
        Log.e("glide", "request stop --------------");
        // 停止耗时操作
        future.cancel(true);
        executorService.shutdown();
    }

}

我想可以用这种思想带到我们平常在Activity执行耗时操作中,这样我们的耗时操作就可以和我们的Activity生命周期一样,避免内存泄漏!!!

这里先做一个记录,继续分析glide源码!!!!!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值