我们都知道Activity可作为LifecycleOwner
为LiveData
的使用提供条件,那么Activity是如何实现LifecycleOwner的呢?
Activity虽然实现了LifecycleOwner
接口,但是并没有实现相关处理,而是通过添加一个Fragment来代理Lifecycle
的分发。这种通过Fragment代理Activity行为的设计在其他一些库也经常出现,相对来说更加无侵和优雅。
SupportActivity
Activity通过继承SupportActivity
实现LifecycleOwner
接口。注意在AndroidX中SupportActivity改名为ComponentActivity
public class SupportActivity extends Activity implements LifecycleOwner {
...
private LifecycleRegistry mLifecycleRegistry = new LifecycleRegistry(this);
...
@Override
protected void onSaveInstanceState(Bundle outState) {
mLifecycleRegistry.markState(Lifecycle.State.CREATED);
super.onSaveInstanceState(outState);
}
...
@Override
public Lifecycle getLifecycle() {
return mLifecycleRegistry;
}
}
SupportActivity
声明了mLifecycleRegistry
对象,但是没有直接使用其进行生命周期的分发,而是被ReportFragment
通过activity.getLifecycle()
获取使用。
ReportFragment
SupportActivity
在onCreate
为自己添加了ReportFragment
:
@RestrictTo(LIBRARY_GROUP)
public class SupportActivity extends Activity implements LifecycleOwner {
// ...
@Override
@SuppressWarnings("RestrictedApi")
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ReportFragment.injectIfNeededIn(this);
}
// ...
}
低版本Activity兼容Lifecycle
SupportActivity
是伴随Lifecycle才出现的,android.arch.lifecycle:extensions
为早期还没有继承SupportActivity
的Activity也提供了支持,通过LifecycleDispatcher
实现ReportFragment的注入:
class LifecycleDispatcher {
static void init(Context context) {
if (sInitialized.getAndSet(true)) {
return;
}
((Application) context.getApplicationContext())
.registerActivityLifecycleCallbacks(new DispatcherActivityCallback());
}
static class DispatcherActivityCallback extends EmptyActivityLifecycleCallbacks {
private final FragmentCallback mFragmentCallback;
DispatcherActivityCallback() {
mFragmentCallback = new FragmentCallback();
}
@Override
public void onActivityCreated(Activity activity, Bundle savedInstanceState) {
if (activity instanceof FragmentActivity) {
((FragmentActivity) activity).getSupportFragmentManager()
.registerFragmentLifecycleCallbacks(mFragmentCallback, true);
}
ReportFragment.injectIfNeededIn(activity);
}
}
}
之前还疑惑为什么ReportFragment
的实现不写到SupportActivity
中去,看到这里终于理解了其存在的意义了吧。
LifecycleDispatcher
并不需要在Application中调用,他通过ContentProvider
实现初始化
public class ProcessLifecycleOwnerInitializer extends ContentProvider {
@Override
public boolean onCreate() {
LifecycleDispatcher.init(getContext());
ProcessLifecycleOwner.init(getContext());
return true;
}
}
在android.arch.lifecycle:extensionsaar
的Android
Manifest
中注册:
${applicationId}
占位符,避免authroities
冲突。
可见在无侵这件事情上做到了极致,这种无侵的初始化方法非常值得我们借鉴和使用。
两种Fragment
通过上面分析,我们知道Activity是通过ReportFragment代理了LifecycleOwner
的实现。那么在Activity中添加的LifecycleOwner
与Activity的Fragment的生命周期是否一致呢?答案是否定的
Android中存在两种Fragment有两种:
- ADK自带的
android.app.Fragment
- Support包中的
android.support.v4.app.Fragment
(AndroidX也归为此类)
由于前者已经被@Deprecated
,所以现在普遍使用的是后者,也就是Support或者AndroidX的Fragment。而出于低版本兼容性的考虑,ReportFragment是前者。
Activity对于两种Fragment生命周期回调的实际并不相同,以onResume和onStart为例,Activity回调的实际如下表:
上面表格中()
中的数字表示依次执行的顺序,所以你会发现,sdk fragment
的onStart
晚于support fragment
,而onResume
却更早执行
Activity的LifecycleOwner
虽然是基于Fragment实现的,但是同一个Activity的LifecycleOwner
与Fragment的生命周期回调实际并不一致。
这在我们的开发重要特备注意,不要视图让Fragment和LifecycleOwner
的生命周期中的处理产生时序上的依赖关系。
总结
*通过源码分析Activity对于LifecycleOwner
的实现后,我们得到以下结论
- Activity不直接调用
HandleLifecycleEvent
进行生命周期的分发,而是通过ReportFragment实现 - ReportFragment的注入和过程全程无侵,值得我们借鉴和学习
- 同一个Activity,其
LifecycleOwner
与Fragment的生命周期回调实际并不一致,需要特别注意
Android高级开发系统进阶笔记、最新面试复习笔记PDF,我的GitHub
文末
您的点赞收藏就是对我最大的鼓励!
欢迎关注我,分享Android干货,交流Android技术。
对文章有何见解,或者有何技术问题,欢迎在评论区一起留言讨论!