首页 > 其他分享 >Android JecPack组件之LifeCycles 使用详解

Android JecPack组件之LifeCycles 使用详解

时间:2025-01-19 20:57:25浏览次数:3  
标签:JecPack 生命周期 LifeCycles override TAG Activity fun Android Lifecycle

一、背景

LifeCycle 是一个可以感知宿主生命周期变化的组件。常见的宿主包括 Activity/Fragment、Service 和 Application。LifeCycle 会持有宿主的生命周期状态的信息,当宿主生命周期发生变化时,会通知监听宿主的观察者。

LifeCycle 的出现主要是为了解决: 系统组件的生命周期与普通组件之间的耦合性。

  • 系统组件指:Activity/Fragment、Service 和 Application。

  • 普通组件指:将代码按照功能或者作用封装成的组件。

比如要想在某个Acvitity组件的不同生命周期执行不同的业务代码,现在有下面三种方式:

1.1 第一种:直接在Activity文件里去针对不同的生命周期函数里去写业务代码。

这样会造成Activity代码里充斥着大量的业务逻辑,而且不利于解耦,后期会所有的逻辑堆叠在Activity文件里。

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity

class LoginActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_login)
        Log.i(TAG, "onCreate")
    }
    
    override fun onStart() {
        Log.i(TAG, "onStart")
    }

    override fun onResume() {
        Log.i(TAG, "onResume")
    }

    override fun onPause() {
        Log.i(TAG, "onPause")
    }

    override fun onStop() {
        Log.i(TAG, "onStop")
    }

    override fun onDestroy() {
        Log.i(TAG, "onDestroy")
    }
}

1.2 第二种:通过生命周期的接口解耦

比如声明一个LifeListener的接口,暴露各个声明周期

interface LifeListener {

    fun onCreate()

    fun onStart()

    fun onResume()

    fun onPause()

    fun onStop()

    fun onDestroy()

}

接着在Activity文件的声明周期里,只需要在这个Activity里注册这个接口的实现类,然后在不同的生命周期函数里通过mLifeListener去分发不同生命周期时机,这样业务逻辑就可以在这个接口的实现类里去做,解耦了Activity和业务逻辑。

package com.example.databindingproject

import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity

class LoginActivity : AppCompatActivity() {

    private lateinit var mLifeListener: LifeListener

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_login)

        mLifeListener = ActivityLifeListener()
    }

    override fun onStart() {
        super.onStart()
        mLifeListener.onStart()
    }

    override fun onResume() {
        super.onResume()
        mLifeListener.onResume()
    }

    override fun onPause() {
        super.onPause()
        mLifeListener.onPause()
    }

    override fun onStop() {
        super.onStop()
        mLifeListener.onStop()
    }

    override fun onDestroy() {
        super.onDestroy()
        mLifeListener.onDestroy()
    }
}

LifeListener的实现类,关于生命周期要执行的业务逻辑,可以放到这个实现类里。

class ActivityLifeListener : LifeListener {

    companion object {
        const val TAG = "ActivityLifeListener"
    }

    override fun onCreate() {
        Log.i(TAG, "onCreate")
    }

    override fun onStart() {
        Log.i(TAG, "onStart")
    }

    override fun onResume() {
        Log.i(TAG, "onResume")
    }

    override fun onPause() {
        Log.i(TAG, "onPause")
    }

    override fun onStop() {
        Log.i(TAG, "onStop")
    }

    override fun onDestroy() {
        Log.i(TAG, "onDestroy")
    }
}

这种方式的优点就是原理简单,缺点是但仍然需要在Acvitity UI组件类的去显示的调用不同生命周期声明方法,比如仍然需要显示的在Activity的onStart方法里去通过 mLifeListener.onStart() 触发在onStart方法里执行的业务逻辑代码。

1.3 第三种:通过Jetpack 组件的LifeCycles解耦

比如需要感知Activity的声明周期,则可以通过实现DefaultLifecycleObserver接口或者LifecycleObserver接口,然后再在Activity的onCreate生命周期里绑定这个实现类实例,则可以在实现类里对不同生命周期实现自己独立的业务逻辑,并且还不会需要显示的在Activity的其他生命周期显示调用分发了,代码层面

class MainActivity : AppCompatActivity() {

   override fun onCreate(savedInstanceState: Bundle?) {
       // 绑定对应的Observer实现接口
       // DefaultLifecycleObserver实现类方式
       lifecycle.addObserver(LoginLifeCycleObserver())
       // LifecycleEventObserver的实现类 方式
       lifecycle.addObserver(CardLifeCycleObserver())
   }
}

DefaultLifecycleObserver实现类 方式

import android.util.Log
import androidx.lifecycle.DefaultLifecycleObserver
import androidx.lifecycle.LifecycleOwner

class LoginLifeCycleObserver : DefaultLifecycleObserver {

    companion object {
        const val TAG = "LifeCycleListener"
    }

    override fun onCreate(owner: LifecycleOwner) {
        super.onCreate(owner)
        Log.i(TAG, "==> onCreate")
    }

    override fun onStart(owner: LifecycleOwner) {
        super.onStart(owner)
        Log.i(TAG, "==> onStart")
    }

    override fun onResume(owner: LifecycleOwner) {
        super.onResume(owner)
        Log.i(TAG, "==> onResume")
    }

    override fun onPause(owner: LifecycleOwner) {
        super.onPause(owner)
        Log.i(TAG, "==> onPause")
    }

    override fun onStop(owner: LifecycleOwner) {
        super.onStop(owner)
        Log.i(TAG, "==> onStop")
    }

    override fun onDestroy(owner: LifecycleOwner) {
        super.onDestroy(owner)
        Log.i(TAG, "==> onDestroy")
    }

}

日志打印,业务执行

LifecycleEventObserver的实现类 方式

import android.util.Log
import androidx.lifecycle.Lifecycle
import androidx.lifecycle.LifecycleEventObserver
import androidx.lifecycle.LifecycleOwner

class CardLifeCycleObserver : LifecycleEventObserver {

    companion object {
        const val TAG = "CardLifeCycleObserver"
    }

    override fun onStateChanged(source: LifecycleOwner, event: Lifecycle.Event) {
        when(event) {
            Lifecycle.Event.ON_CREATE -> Log.i(TAG, "onStateChanged==> onCreate")
            Lifecycle.Event.ON_START -> Log.i(TAG, "onStateChanged==> onStart")
            Lifecycle.Event.ON_RESUME -> Log.i(TAG, "onStateChanged==> onResume")
            Lifecycle.Event.ON_PAUSE -> Log.i(TAG, "onStateChanged==> onPause")
            Lifecycle.Event.ON_STOP -> Log.i(TAG, "onStateChanged==> onStop")
            Lifecycle.Event.ON_DESTROY -> Log.i(TAG, "onStateChanged==> onDestroy")
            Lifecycle.Event.ON_ANY -> Log.i(TAG, "onStateChanged==> onAny")
        }
    }
}

综上,可以看到第三种会解耦程度最大

二、LifeCycles优点

一句话简述成:Android Lifecycles 的优点是简化了生命周期管理,通过 LifecycleObserver 使生命周期相关的逻辑从 ActivityFragment 中解耦,提高了代码的可维护性和可复用性。

三、LifeCycles使用

Jetpack 为我们提供了两个接口:

  • 被观察者:​​LifecycleOwner​

  • 观察者:​​LifecycleObserver​

被监听的系统组件需要去实现 LifecycleOwner 接口,观察者需要实现 LifecycleObserver 接口。

使用被观察者接口LifecycleOwner

在 AndroidX 里面 ComponentActivity 已经默认实现了 LifecycleOwner 接口。如果项目没有迁移到 AndroidX,还是用的 Support 库,新版本的 SDK 也通过 SupportActivity 实现了 LifecycleOwner 接口。因此我们默认在Activity或者Fragement里是不需要额外去实现LifecycleOwner接口,只需要去实现LifecycleObserver接口即可。

使用观察者接口LifecycleObserver

class LoginLifeCycleObserver : DefaultLifecycleObserver {

    companion object {
        const val TAG = "LifeCycleListener"
    }

    override fun onCreate(owner: LifecycleOwner) {
        super.onCreate(owner)
        Log.i(TAG, "==> onCreate")
    }

    override fun onStart(owner: LifecycleOwner) {
        super.onStart(owner)
        Log.i(TAG, "==> onStart")
    }

    override fun onResume(owner: LifecycleOwner) {
        super.onResume(owner)
        Log.i(TAG, "==> onResume")
    }

    override fun onPause(owner: LifecycleOwner) {
        super.onPause(owner)
        Log.i(TAG, "==> onPause")
    }

    override fun onStop(owner: LifecycleOwner) {
        super.onStop(owner)
        Log.i(TAG, "==> onStop")
    }

    override fun onDestroy(owner: LifecycleOwner) {
        super.onDestroy(owner)
        Log.i(TAG, "==> onDestroy")
    }

}

然后在需要的Activity里添加这个观察者实现的实例对象

class MainActivity : AppCompatActivity() {

   override fun onCreate(savedInstanceState: Bundle?) {
       // 绑定对应的Observer实现接口
       // DefaultLifecycleObserver实现类方式
       lifecycle.addObserver(LoginLifeCycleObserver())
   }
}

或者在需要的Fragment里添加

class LoginFragment : Fragment() {

    override fun onCreateView(
        inflater: LayoutInflater, container: ViewGroup?,
        savedInstanceState: Bundle?
    ): View? {
        // Inflate the layout for this fragment
        val binding = inflater.inflate(R.layout.fragment_login, container, false)

        // 创建生命周期观察者实例
        val lifecycleObserver = LoginLifeCycleObserver()

        // 注册生命周期观察者
        lifecycle.addObserver(lifecycleObserver)

        return binding
    }
}

四、原理

LifeCycles核心思想

本质上是围绕着这两个设计模式进行的:

  • 模板模式 → 定义算法骨架,对外开放扩展点,基于 继承 关系实现,子类重写父类抽象方法;

  • 观察者模式 → 对象间定义一对多的依赖,当一个对象状态发生改变,依赖对象都会自动收到通知;

在探究原理的时候,可以思考下面四个问题:

  • Lifecycle是怎样感知生命周期的?

  • Lifecycle是如何处理生命周期的?

  • LifecycleObserver的方法是怎么回调的呢?

  • 为什么LifecycleObserver可以感知到Activity的生命周期

LifecycleOwner.kt

public interface LifecycleOwner {
    /**
     * Returns the Lifecycle of the provider.
     *
     * @return The lifecycle of the provider.
     */
    public val lifecycle: Lifecycle
}

生命周期持有者,返回一个Lifecycle对象,如果你使用的是 AndroidX(也属于 Jetpack 一部分)在这Activity 、Fragment 两个类中,默认实现了 LifecycleOwner 接口

Lifecycle.kt

public abstract class Lifecycle {

    @MainThread
    public abstract fun addObserver(observer: LifecycleObserver)

    @MainThread
    public abstract fun removeObserver(observer: LifecycleObserver)
    
    @get:MainThread
    public abstract val currentState: State

    public enum class Event {
        ON_CREATE,
        ON_START,
        ON_RESUME,
        ON_PAUSE,
        ON_STOP,
        ON_DESTROY,
        ON_ANY;
        public val targetState: State
            get() {
                when (this) {
                    ON_CREATE, ON_STOP -> return State.CREATED
                    ON_START, ON_PAUSE -> return State.STARTED
                    ON_RESUME -> return State.RESUMED
                    ON_DESTROY -> return State.DESTROYED
                    ON_ANY -> {}
                }
                throw IllegalArgumentException("$this has no target state")
            }

        public companion object {
            @JvmStatic
            public fun downFrom(state: State): Event? {
                return when (state) {
                    State.CREATED -> ON_DESTROY
                    State.STARTED -> ON_STOP
                    State.RESUMED -> ON_PAUSE
                    else -> null
                }
            }

            @JvmStatic
            public fun downTo(state: State): Event? {
                return when (state) {
                    State.DESTROYED -> ON_DESTROY
                    State.CREATED -> ON_STOP
                    State.STARTED -> ON_PAUSE
                    else -> null
                }
            }

            @JvmStatic
            public fun upFrom(state: State): Event? {
                return when (state) {
                    State.INITIALIZED -> ON_CREATE
                    State.CREATED -> ON_START
                    State.STARTED -> ON_RESUME
                    else -> null
                }
            }

            @JvmStatic
            public fun upTo(state: State): Event? {
                return when (state) {
                    State.CREATED -> ON_CREATE
                    State.STARTED -> ON_START
                    State.RESUMED -> ON_RESUME
                    else -> null
                }
            }
        }
    }

   
    public enum class State {
        DESTROYED,
        INITIALIZED,
        CREATED,
        STARTED,
        RESUMED;
        public fun isAtLeast(state: State): Boolean {
            return compareTo(state) >= 0
        }
    }
}

在Lifecycle类中定义了添加观察者移除观察者的方法,并定义了两个枚举类Event、State

Event:定一个一些枚举常量,和 Activity、Fragment 的生命周期是一一对应的,可以响应其生命周期,其中多了一个ON_ANY,它是可以匹配任何事件的,Event 的使用是和 LifecycleObserver 配合使用的,

State:当前Lifecycle的自己的目前的状态,它是和Event配合使用的

Event和State之间的关系

如下图

LifecycleRegistry类是对Lifecycle这个抽象类的具体实现,可以处理多个观察者,如果你自定义 LifecycleOwner可以直接使用它。

LifecycleRegistry.kt

open class LifecycleRegistry private constructor(
    provider: LifecycleOwner,
    private val enforceMainThread: Boolean
) : Lifecycle() {

    override fun addObserver(observer: LifecycleObserver) {
        enforceMainThreadIfNeeded("addObserver")
        val initialState = if (state == State.DESTROYED) State.DESTROYED else State.INITIALIZED
        val statefulObserver = ObserverWithState(observer, initialState)
        val previous = observerMap.putIfAbsent(observer, statefulObserver)
        if (previous != null) {
            return
        }
        val lifecycleOwner = lifecycleOwner.get()
            ?: // it is null we should be destroyed. Fallback quickly
            return
        val isReentrance = addingObserverCounter != 0 || handlingEvent
        var targetState = calculateTargetState(observer)
        addingObserverCounter++
        while (statefulObserver.state < targetState && observerMap.contains(observer)
        ) {
            pushParentState(statefulObserver.state)
            val event = Event.upFrom(statefulObserver.state)
                ?: throw IllegalStateException("no event up from ${statefulObserver.state}")
            statefulObserver.dispatchEvent(lifecycleOwner, event)
            popParentState()
            // mState / subling may have been changed recalculate
            targetState = calculateTargetState(observer)
        }
        if (!isReentrance) {
            // we do sync only on the top level.
            sync()
        }
        addingObserverCounter--
    }
    
    override fun removeObserver(observer: LifecycleObserver) {
        enforceMainThreadIfNeeded("removeObserver")
        observerMap.remove(observer)
    }
}

LifecycleObserver

就是一个简单的接口,这个接口只是来标志这个是对Lifecycle的观察者,内部没有任何方法,全部都依赖于DefaultLifecycleObserver

总结:

  • LifecycleOwner:可获取Lifecycle的接口,可以再 Activity、Fragment生命周期改变时,通过LifecycleRegistry类处理对应的生命周期事件,并通知 LifecycleObserver这个观察者

  • Lifecycle:是被观察者,用于存储有关组件(如 Activity 或 Fragment)的生命周期状态的信息,并允许其他对象观察此状态。

  • LifecycleObserver:观察者,可以通过被LifecycleRegistry类通过 addObserver(LifecycleObserver o)方法注册,被注册后,LifecycleObserver便可以观察到LifecycleOwner对应的生命周期事件

  • Lifecycle.Event:分派的生命周期事件。这些事件映射到 Activity 和 Fragment 中的回调事件。

  • Lifecycle.State:Lifecycle组件的当前状态。

4.Lifecycle的源码解析

4.1 分析的入口BaseActivity

在基类BaseActivity中的一行代码就能实现对应生命周期的回调

openclassBaseActivity : AppCompatActivity() {
    overridefunonCreate(savedInstanceState:Bundle?) {
        super.onCreate(savedInstanceState)
        lifecycle.addObserver(ActivityLifecycleObserver())//1
    }
}

我们先看下getLifecycle() 方法,然后在看addObserver(ActivityLifecycleObserver())的内容,注意这时候分成两步了,我们先看getLifecycle()

我们点进去这个getLifecycle()方法。

4.2 ComponentActivity 类

然后我们来到了ComponentActivity中,代码如下

public class ComponentActivity extends xxx implements LifecycleOwner,xxx {//1

	private final LifecycleRegistry mLifecycleRegistry = new LifecycleRegistry(this);//2

	@Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        ...
        super.onCreate(savedInstanceState);
        ReportFragment.injectIfNeededIn(this);//4
        ...
        
    }

    public Lifecycle getLifecycle() {
        return mLifecycleRegistry;//3
    }

}

在onCreate方法中有一行代码ReportFragment.injectIfNeededIn(this);

在onCreate方法中,看到初始化了一个ReportFragment,接下来看一下ReportFragment的源码

public class ReportFragment extends Fragment {
	
    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
        dispatchCreate(mProcessListener);
        dispatch(Lifecycle.Event.ON_CREATE);·
    }

    @Override
    public void onStart() {
        super.onStart();
        dispatchStart(mProcessListener);
        dispatch(Lifecycle.Event.ON_START);
    }

    @Override
    public void onResume() {
        super.onResume();
        dispatchResume(mProcessListener);
        dispatch(Lifecycle.Event.ON_RESUME);
    }

    @Override
    public void onPause() {
        super.onPause();
        dispatch(Lifecycle.Event.ON_PAUSE);
    }

    @Override
    public void onStop() {
        super.onStop();
        dispatch(Lifecycle.Event.ON_STOP);
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        dispatch(Lifecycle.Event.ON_DESTROY);
        // just want to be sure that we won't leak reference to an activity
        mProcessListener = null;
    }

    private void dispatch(Lifecycle.Event event) {
        Activity activity = getActivity();
      	//1
        if (activity instanceof LifecycleRegistryOwner) {
            ((LifecycleRegistryOwner) activity).getLifecycle().handleLifecycleEvent(event);
            return;
        }
				//2
        if (activity instanceof LifecycleOwner) {
            Lifecycle lifecycle = ((LifecycleOwner) activity).getLifecycle();
            if (lifecycle instanceof LifecycleRegistry) {
                ((LifecycleRegistry) lifecycle).handleLifecycleEvent(event);
            }
        }
    }
}

可以看到在 ReportFragment 中的各个生命周期都调用了dispatch(Lifecycle.Event event)方法,传递了不同的Event的值,这个就是在Activity、Fragment的各个生命周期回调时,Lifecycle 所要处理的生命周期方法。

在dispatch(Lifecycle.Event event)方法中最终调用了((LifecycleRegistry) lifecycle).handleLifecycleEvent(event);方法

这里可以解答之前的两个问题

1.Lifecycle是怎样感知生命周期的?

就是在ReportFragment中的各个生命周期都调用了dispatch(Lifecycle.Event event)方法,传递了不同的Event的值

2.Lifecycle是如何处理生命周期的?

通过调用了((LifecycleRegistry) lifecycle).handleLifecycleEvent(event);方法,也就是LifecycleRegistry 类来处理这些生命周期。

此时,就应该看 LifecycleRegistry 的handleLifecycleEvent方法中的代码了

查看handleLifecycleEvent方法的实现,根据当前Lifecycle.Event的值,其实也就是 Activity、Fragment 生命周期回调的值,来获取下一个Lifecycle.State的状态,也就是 Lifecycle 将要到什么状态

open fun handleLifecycleEvent(event: Event) {
    enforceMainThreadIfNeeded("handleLifecycleEvent")
    moveToState(event.targetState)
}

private fun moveToState(next: State) {
    // 如果之前的状态和下一个相同,则直接返回
    if (state == next) {
        return
    }
    // 检查状态
    check(!(state == State.INITIALIZED && next == State.DESTROYED)) {
        "no event down from $state in component ${lifecycleOwner.get()}"
    }
    // 当前状态变量被赋值为next的值
    state = next
    // 如果正在处理事件或者已经添加的观察器数量不为0,则标记一下直接返回
    if (handlingEvent || addingObserverCounter != 0) {
        newEventOccurred = true
        // we will figure out what to do on upper level.
        return
    }
    handlingEvent = true
    sync()
    handlingEvent = false
    if (state == State.DESTROYED) {
        observerMap = FastSafeIterableMap()
    }
}

然后看 LifecycleRegistry 的sync方法

LifecycleRegistry.java

private void sync() {
    LifecycleOwnerlifecycleOwner = mLifecycleOwner.get();
    if (lifecycleOwner == null) {
        thrownewIllegalStateException("LifecycleOwner of this LifecycleRegistry is already"
                + "garbage collected. It is too late to change lifecycle state.");
    }
    while (!isSynced()) {
        mNewEventOccurred = false;
        // no need to check eldest for nullability, because isSynced does it for us.
        if (mState.compareTo(mObserverMap.eldest().getValue().mState) < 0) {
            backwardPass(lifecycleOwner);//1
        }
        Entry<LifecycleObserver, ObserverWithState> newest = mObserverMap.newest();
        if (!mNewEventOccurred && newest != null
                && mState.compareTo(newest.getValue().mState) > 0) {
            forwardPass(lifecycleOwner);//2
        }
    }
    mNewEventOccurred = false;
}

如果没有同步过,会比较mState当前的状态和mObserverMap中的eldest和newest的状态做对比,看是往前还是往后;比如mState由STARTED到RESUMED是状态向前,反过来就是状态向后。这个是和 Lifecycle 生命周期有关系,但不是一个东西,具体的看上面贴的图,一目了然!

我们发现,无论如何,最终都会走到(ObserverWithState)observer.dispatchEvent(lifecycleOwner, event), 即最终调用LifecycleObserver.onStateChanged(owner, event)

public interface LifecycleEventObserver extends LifecycleObserver {
    void onStateChanged(@NonNull LifecycleOwner source, @NonNull Lifecycle.Event event);
}

生命周期变化时

  • ActivityThread通知Activity,Activity(无论何种方式)通知 ReportFragment

  • ReportFragment调用 LifecycleRegistry.handleLifecycleEvent(event)

  • LifecycleRegistry经过 moveToState() -> sync() -> backwardPass()/forwardPass() 最终调用ObserverWithState.dispatchEvent()

  • ObserverWithState.dispatchEvent() 调用LifecycleObserver.onStateChanged() 通知 CallbackInfo 通过反射执行对应方法

  • CallbackInfo.invokeCallbacks()查找到对应生命周期的 MethodReference 缓存,通过Method.invoke()调用,最终执行LifecycleObserver中关注对应生命周期的方法。

在来回顾当初抛出的问题

1.Lifecycle是怎样感知生命周期的?

就是在ReportFragment中的各个生命周期都调用了dispatch(Lifecycle.Event event) 方法,传递了不同的Event的值

2.Lifecycle是如何处理生命周期的?

通过调用了((LifecycleRegistry) lifecycle).handleLifecycleEvent(event);方法,也就是LifecycleRegistry 类来处理这些生命周期。

3.LifecycleObserver的方法是怎么回调是的呢?

LifecycleRegistry 的 handleLifecycleEvent方法,然后会通过层层调用最后通过反射到LifecycleObserver方法上的@OnLifecycleEvent(Lifecycle.Event.XXX)注解值,来调用对应的方法

4.为什么LifecycleObserver可以感知到Activity的生命周期
  • ActivityThread产生生命周期事件并通过Instrumentation和Activity传递或调用 Activity.onXXX()

  • Activity创建时(onCreate)会被注入ReportFragment,而ReportFragment负责将生命周期事件分发给对应的Lifecycle

  • API29及以上时,Activity在处理生命周期时会通知 Application 处理生命周期回调且自身也同样处理生命周期回调,API29以上这些回调将会被ReportFragment接收,而API29以下则由FragmentController直接分发给ReportFragment。

五、拓展

比如现在需要实现监听所有Activity的生命周期变化过程的功能,那么如何利用LifeCycles最小改动就能实现这个功能呢?

5.1 创建LifeCycles接口

首先,创建一个 LifeCycles 接口,用于定义需要的生命周期事件方法。

interface LifeCycles {
    fun onActivityCreated(activity: Activity)
    fun onActivityStarted(activity: Activity)
    fun onActivityResumed(activity: Activity)
    fun onActivityPaused(activity: Activity)
    fun onActivityStopped(activity: Activity)
    fun onActivityDestroyed(activity: Activity)
    fun onActivitySaveInstanceState(activity: Activity, outState: Bundle)
}

5.2 创建 LifeCycleObserver 实现 ActivityLifecycleCallbacks

然后,创建一个 LifeCycleObserver 类,它会实现 Application.ActivityLifecycleCallbacks,并调用 LifeCycles 接口的方法。

import android.app.Activity
import android.app.Application
import android.os.Bundle

class LifeCycleObserver(private val lifeCycles: LifeCycles) : Application.ActivityLifecycleCallbacks {

    override fun onActivityCreated(activity: Activity, savedInstanceState: Bundle?) {
        lifeCycles.onActivityCreated(activity)
    }

    override fun onActivityResumed(activity: Activity) {
        lifeCycles.onActivityResumed(activity)
    }

    override fun onActivityPaused(activity: Activity) {
        lifeCycles.onActivityPaused(activity)
    }

    override fun onActivityStopped(activity: Activity) {
        lifeCycles.onActivityStopped(activity)
    }

    override fun onActivityDestroyed(activity: Activity) {
        lifeCycles.onActivityDestroyed(activity)
    }

    override fun onActivitySaveInstanceState(activity: Activity, outState: Bundle) {
        // 可选实现
        lifeCycles.onActivitySaveInstanceState(activity, outState)
    }

    override fun onActivityStarted(activity: Activity) {
        // 可选实现
        lifeCycles.onActivityStarted(activity)
    }
}

5.3 在 Application 类中注册 LifeCycleObserver

Application 类中注册 ActivityLifecycleCallbacks,并传递 LifeCycles 接口的实现。

import android.app.Activity
import android.app.Application
import android.os.Bundle
import android.util.Log

class MyApplication : Application() {

    companion object {
        const val TAG = "MyApplication"
    }

    override fun onCreate() {
        super.onCreate()

        // 实现 LifeCycles 接口,处理所有 Activity 生命周期事件
        val lifeCycles = object : LifeCycles {
            override fun onActivityCreated(activity: Activity) {
                // 这里可以监听到 Activity 的 onCreate 事件
                Log.i(TAG, "Activity Created: ${activity.localClassName}")
            }

            override fun onActivityStarted(activity: Activity) {
                // 这里可以监听到 Activity 的 onStart 事件
                Log.i(TAG, "Activity Started: ${activity.localClassName}")
            }

            override fun onActivityResumed(activity: Activity) {
                // 这里可以监听到 Activity 的 onResume 事件
                Log.i(TAG, "Activity Resumed: ${activity.localClassName}")
            }

            override fun onActivityPaused(activity: Activity) {
                // 这里可以监听到 Activity 的 onPause 事件
                Log.i(TAG, "Activity Paused: ${activity.localClassName}")
            }

            override fun onActivityStopped(activity: Activity) {
                // 这里可以监听到 Activity 的 onStop 事件
                Log.i(TAG, "Activity Stopped: ${activity.localClassName}")
            }

            override fun onActivityDestroyed(activity: Activity) {
                // 这里可以监听到 Activity 的 onDestroy 事件
                Log.i(TAG, "Activity Destroyed: ${activity.localClassName}")
            }

            override fun onActivitySaveInstanceState(activity: Activity, outState: Bundle) {
                Log.i(TAG, "Activity onActivitySaveInstanceState: ${activity.localClassName}")
            }
        }

        // 注册 ActivityLifecycleCallbacks
        val lifeCycleObserver = LifeCycleObserver(lifeCycles)
        registerActivityLifecycleCallbacks(lifeCycleObserver)
    }
}

5.4 在 AndroidManifest.xml 中配置 Application

确保在 AndroidManifest.xml 文件中正确声明了自定义的 Application 类:


<application
    android:name=".MyApplication"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/Theme.AppCompat.Light">
    <!-- 其他配置 -->
</application>

最后看一下从MainActivity点击一个按钮跳转去LoginAcitivty,这样能够监听到任何Activity的生命周期变化。

参考:

  1. 【掘金】Jetpack 之 LifeCycle 组件使用详解 https://juejin.cn/post/7086763634864422920

  2. 【掘金】【Jetpack】学穿:Lifecycle → 生命周期 (原理篇) https://juejin.cn/post/7071144317636575262

  3. 【Github】Lifecycle基本使用和原理分析

  4. Jetpack之生命周期感知组件-Lifecycle原理篇

标签:JecPack,生命周期,LifeCycles,override,TAG,Activity,fun,Android,Lifecycle
From: https://blog.csdn.net/qq_41688840/article/details/145164774

相关文章

  • AndroidStudio:GPS定位与网络定位定位服务
    前言:如今主流的定位方式有两种:GPS定位和网络定位。GPS即通过卫星定位,网络定位则需要通过手机附近的基站,WIFI等确定位置信息。二者的优缺点各有不同,Gps较为精准但是耗电量大,网络定位功耗小但是不精确。这篇文章会以LocationManager为例,讲解如何在Androidstudio中使用这两种定位......
  • Android系统开发(十):标准协议和通讯的桥梁:探索蓝牙、NFC、WLAN 的工作原理
    引言:现代社会已经是信息互联的世界,各种设备之间的互联互通已经成为了生活的一部分。而在这个过程中,Android设备与其他硬件之间的通信扮演着至关重要的角色。从蓝牙耳机到WiFi路由器,甚至与电话功能的互动,所有这些连接都依赖于标准Android连接协议的支持。本篇文章将带......
  • Android程序导入unity工程
    用到的软件1.AndroidStudio2.Unity3D1.AndroidStudio生成Arr包1.1Android中所有的Activity都必须继承Activity类,不能继承默AppCompatActivity1.2修改Res文件下的styles修改前修改后1.3将applyplugin:'com.android.application'改成applyplugin:'com.androi......
  • 用Python检查Android字符串文件通配符
    #!/usr/bin/envpython3importosimportsysfromdatetimeimportdatetime,timedeltaimportreimportxml.etree.ElementTreeasETiflen(sys.argv)<3:exit()print(datetime.now(),'start')timestamp=int(datetime.now().timestamp())en_t......
  • 用Shell检查Android字符串文件通配符
    #!/bin/sh#$1=english$2=others$3=outputif[[$3]];thendate+%F""%T"--------------------start---------------------">>$3fitimestamp=`date+%s`en_type=others_type=#获得第1个参数最后3个字符为后缀en_postfix=`echo${1:-3}`others_......
  • SpringBoot基于Android的建筑工地施工项目管理系统的设计与实现
    1.引言在当今的软件开发领域,企业级应用的开发和部署速度直接影响着业务的竞争力。SpringBoot以其轻量级、快速启动和强大的集成能力,成为构建现代企业级应用的首选框架。本文将带您深入了解SpringBoot框架的核心特性,并展示如何利用它构建一个高效、可扩展的系统。2.开发......
  • Android Audio基础(53)——PCM逻辑设备Write数据
    1.前言本文,我们将以回放(Playback,播放音频)为例,讲解PCMData是如何从用户空间到内核空间,最后传递到Codec硬件。在ASoC音频框架简介中,我们给出了回放(Playback)PCM数据流示意图。:对于Linux来说,由于分为userspace和kernelspace,而且两者之间数据不能随便互相访问。因此用......
  • 毕业论文-基于Android的个性化推荐外卖点餐APP系统设计与实现
    内容涵盖详细视频演示文章底部名片,联系我获取更详细的演示视频系统演示截图技术框架后端框架支持:Java(SpringBoot)、Python、PHP、ASP等都可以作为后端支持,具体需求PHP:PHP是一种广泛应用于Web开发的服务器端脚本语言,因其简单易学和强大的生态系统而受到许多开发......
  • 毕业论文-基于Android的智能考勤系统设计与实现
    内容涵盖详细视频演示文章底部名片,联系我获取更详细的演示视频系统演示截图技术框架后端框架支持:Java(SpringBoot)、Python、PHP、ASP等都可以作为后端支持,具体需求PHP:PHP是一种广泛应用于Web开发的服务器端脚本语言,因其简单易学和强大的生态系统而受到许多开发......
  • Android Studio:Linux环境下安装与配置
    AndroidStudio:Linux环境下安装与配置1.安装JDK2.安装AndroidStudio2.1获取安装包2.2安装(1)配置环境变量:(2)运行安装:(3)配置AndroidSDK路径:3.安装AndroidNDK3.1通过AndroidStudio的SDKManager安装3.2手动下载安装包以下是在Ubuntu下安装AndroidStudio的说......