前言
為了幫助開發(fā)者更高效,更容易地構(gòu)建優(yōu)秀的應(yīng)用沪蓬,在 2018 Google IO 大會上跷叉,谷歌正式推出了 Android Jetpack Components 系列架構(gòu)組件营搅。本文的主題是 Lifecycle
转质,它可以有效的避免內(nèi)存泄漏,和解決 Android
中生命周期常見的難題沸枯。
在最近學(xué)習(xí)官方的架構(gòu)組件時,我詢問了我的朋友哪轿,他指導(dǎo)我的學(xué)習(xí)順序為:Lifecycle - ViewModel - LiveData
翔怎。我當(dāng)時很不解,直到我將源碼過了一邊,才發(fā)現(xiàn) Lifecycle
是 ViewModel
和 LiveData
組件的支撐于毙。
使用
1. 首先定義一個類實現(xiàn) LifecycleObserver
接口
class MainPresenter : LifecycleObserver {
@OnLifecycleEvent(Lifecycle.Event.ON_CREATE)
fun onCreate() {
println("MainPresenter: ON_CREATE")
}
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
fun onDestroy() {
println("MainPresenter: ON_DESTROY")
}
}
在對應(yīng)的方法添加 @OnLifecycleEvent
注解唯沮,接下來在 LifecyleOwner
中注冊觀察者介蛉。
2. 在 Activity 中注冊觀察者
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
println("MainActivity: onCreate")
// 注冊觀察者
lifecycle.addObserver(MainPresenter())
}
}
簡單的 2 步操作溶褪,我們的 MainPresenter
就可以感知當(dāng)前 Activity
的生命周期猿妈。
2018-12-06 20:05:50.199 22452-22452/com.i3kmsteady.jetpacksample I/System.out: MainActivity: onCreate
2018-12-06 20:05:50.214 22452-22452/com.i3kmsteady.jetpacksample I/System.out: MainPresenter: ON_CREATE
2018-12-06 20:06:03.159 22452-22452/com.i3kmsteady.jetpacksample I/System.out: MainPresenter: ON_DESTROY
2018-12-06 20:06:03.161 22452-22452/com.i3kmsteady.jetpacksample I/System.out: MainActivity: onDestroy
當(dāng)然了,這只是一個簡單的實例鳍刷。在項目中的具體使用输瓜,冒昧推薦下 卻把清梅嗅 的 MVVM-Rhine芬萍。
3. 如果在項目中使用了 Java8
,推薦使用DefaultLifecycleObserver
class MainPresenter : DefaultLifecycleObserver {
override fun onCreate(owner: LifecycleOwner) {
super.onCreate(owner)
}
}
大概率會遇到以下錯誤:
Super calls to Java default methods are prohibited in JVM target 1.6. Recompile with '-jvm-target 1.8'
在 app 下的 build.gradle
中的 android
閉包中添加以下代碼即可解決:
kotlinOptions{
jvmTarget = '1.8'
}
雖然代碼實現(xiàn)很簡單芹缔,但是我們要保持好奇心最欠,去探究下 Lifecycle
組件的具體實現(xiàn)。
源碼分析
從 MainActivity
中的代碼展開蚜点,來探索一步一步的實現(xiàn)拌阴。
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
// 添加觀察者
lifecycle.addObserver(MainPresenter())
}
1. LifecycleOwner
LifecycleOwner 是描述 Android
生命周期持有者的一個類迟赃。以 Activiy
為例來展開
@RestrictTo({Scope.LIBRARY_GROUP})
public class SupportActivity extends Activity implements LifecycleOwner, Component {
...
protected void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
ReportFragment.injectIfNeededIn(this);
}
@CallSuper
protected void onSaveInstanceState(Bundle outState) {
this.mLifecycleRegistry.markState(State.CREATED);
super.onSaveInstanceState(outState);
}
@RestrictTo({Scope.LIBRARY_GROUP})
public <T extends SupportActivity.ExtraData> T getExtraData(Class<T> extraDataClass) {
return (SupportActivity.ExtraData)this.mExtraDataMap.get(extraDataClass);
}
public Lifecycle getLifecycle() {
return this.mLifecycleRegistry;
}
...
}
lifecycle 返回的是在 SupprotActivity
中初始化的 LifecycleRegistery
對象左刽。
2. Lifecycle
Lifecycle 是表示 Android
生命周期及其狀態(tài)的對象欠痴,具體實現(xiàn)為 LifecycleRegistery
對象。讓我們看下 addObserver()
@Override
public void addObserver(@NonNull LifecycleObserver observer) {
State initialState = mState == DESTROYED ? DESTROYED : INITIALIZED;
ObserverWithState statefulObserver = new ObserverWithState(observer, initialState);
ObserverWithState previous = mObserverMap.putIfAbsent(observer, statefulObserver);
if (previous != null) {
return;
}
LifecycleOwner lifecycleOwner = mLifecycleOwner.get();
if (lifecycleOwner == null) {
// it is null we should be destroyed. Fallback quickly
return;
}
boolean isReentrance = mAddingObserverCounter != 0 || mHandlingEvent;
State targetState = calculateTargetState(observer);
mAddingObserverCounter++;
while ((statefulObserver.mState.compareTo(targetState) < 0
&& mObserverMap.contains(observer))) {
pushParentState(statefulObserver.mState);
statefulObserver.dispatchEvent(lifecycleOwner, upEvent(statefulObserver.mState));
popParentState();
// mState / subling may have been changed recalculate
targetState = calculateTargetState(observer);
}
if (!isReentrance) {
// we do sync only on the top level.
sync();
}
mAddingObserverCounter--;
}
到這一步,似乎自定義的 LifecycleObserver
還是無法感知生命周期菩咨〉┪回過頭去看下 SupportActivity
中的 onCreate()
雏亚,發(fā)現(xiàn)了 ReportFragment
的身影罢低。
3. ReportFragment
ReportFragment 是一個不可見的 Fragment
网持,注入在 SupprotActivity
中功舀。通過 Fragment
去感知生命周期,然后通知到 LifecycleObserver()
列敲。這樣就可以獲取到當(dāng)前的生命周期。以下是ReportFragment
中生命周期的分發(fā)過程
...
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
dispatchCreate(mProcessListener);
// 生命周期分發(fā)
dispatch(Lifecycle.Event.ON_CREATE);
}
...
接下來看下 dispatch()
的實現(xiàn)
private void dispatch(Lifecycle.Event event) {
Activity activity = getActivity();
if (activity instanceof LifecycleRegistryOwner) {
((LifecycleRegistryOwner) activity).getLifecycle().handleLifecycleEvent(event);
return;
}
if (activity instanceof LifecycleOwner) {
Lifecycle lifecycle = ((LifecycleOwner) activity).getLifecycle();
if (lifecycle instanceof LifecycleRegistry) {
((LifecycleRegistry) lifecycle).handleLifecycleEvent(event);
}
}
}
然后調(diào)用 Lifecycle
的 handleLifecycleEvent
去分發(fā)生命周期凑术。
4. LifecyleRegistery
LifecyleRegistery 是 Lifecycle
的實現(xiàn)淮逊,通過調(diào)用 handleLifecycleEvent()
去通知 LifecycleObsever
生命周期發(fā)生了變化扶踊。
public void handleLifecycleEvent(@NonNull Lifecycle.Event event) {
State next = getStateAfter(event);
moveToState(next);
}
5. ObserverWithState
ObserverWithState 是 LifecyleRegistery
的靜態(tài)內(nèi)部類,調(diào)用 dispatchEvent()
去通知 LifecycleObserver
备籽。
void dispatchEvent(LifecycleOwner owner, Event event) {
State newState = getStateAfter(event);
mState = min(mState, newState);
mLifecycleObserver.onStateChanged(owner, event);
mState = newState;
}
通過 debug 調(diào)試,發(fā)現(xiàn) mLifecycleObserver
的最終實現(xiàn)是 ReflectiveGenericLifecycleObserver
杂抽。
6. ReflectiveGenericLifecycleObserver
ReflectiveGenericLifecycleObserver 是 GenericLifecycleObserver
的實現(xiàn)類缩麸。onStateChanged()
最終會調(diào)用到 CallbackInfo
的 invokeCallbacks()
。在其內(nèi)部通過反射杭朱,解析 OnLifecycleEvent
注解弧械,通知到我們所聲明的OnLifecycleEvent
注解的方法上刃唐。
結(jié)語
到此画饥,Lifecycle 的基本流程就已經(jīng)過了一邊。筆者并沒有對源碼展開一步步的分析浊猾,而是從大體上出發(fā)抖甘,對代碼的具體實現(xiàn)還有勞大家私下進(jìn)一步的學(xué)習(xí)。