Android Activity启动过程中事务模式的一点点分析

1. 什么是事务模式?

  • 事务模式又被称为命令模式,在软件开发过程中,经常需要向某些对象发送调用其内部方法的请求,为了使请求发送者和请求接收者解耦,让发送者与接收者没有直接引用的关系,我们可以将请求封装为一个对象,由该对象来调用接收者的具体方法

2. 启动过程中涉及到的事务模式设计

2.1 源码

java 复制代码
frameworks/base/services/core/java/com/android/server/wm/ActivityTaskSupervisor.java

   boolean realStartActivityLocked(ActivityRecord r, WindowProcessController proc,
            boolean andResume, boolean checkConfig) throws RemoteException {

        // ...

        final Task task = r.getTask();
        final Task rootTask = task.getRootTask();

        try {
                // ...

                // 创建启动 Activity 的事务
                final ClientTransaction clientTransaction = ClientTransaction.obtain(
                        proc.getThread(), r.token);

                final boolean isTransitionForward = r.isTransitionForward();
                final IBinder fragmentToken = r.getTaskFragment().getFragmentToken();
                
                // 添加启动 Activity 的 callback,执行launchActivity
                clientTransaction.addCallback(LaunchActivityItem.obtain(new Intent(r.intent),
                        System.identityHashCode(r), r.info,


        // ...

        return true;
    }
 



frameworks/base/core/java/android/app/servertransaction/LaunchActivityItem.java
 // ...
      public void execute(ClientTransactionHandler client, IBinder token,
              PendingTransactionActions pendingActions) {
          Trace.traceBegin(TRACE_TAG_ACTIVITY_MANAGER, "activityStart");
          ActivityClientRecord r = client.getLaunchingActivity(token);
          client.handleLaunchActivity(r, pendingActions, null /* customIntent */);
          Trace.traceEnd(TRACE_TAG_ACTIVITY_MANAGER);
      }
 // ...

2.2 架构图

2.3 解析

  • ClientTransactionItem.java 抽象命令类,继承了一个接口,该接口中包含excute方法

  • LaunchActivityItem 具体命令类,是抽象命令类的子类具体实现了execute方法, 类似的还有ResumeActivityItem,DestroyActivityItem.java 等

  • ClientTransaction 调用者,与命令类是聚合关系,通过addCallback()来加载具体的命令,然后通过schedule()来执行具体命令类的方法

  • ActivityThread 接收者,接收者执行与请求相关的操作,它具体实现对请求的业务处理

2.4 小结

  • 将各个生命周期作为一个个对象进行具体的封装,一种生命周期对应一个对象
  • 将调用者即发出需要执行某个生命周期的类,与接收者即具体执行某个生命周期的类进行分开,调用者与接收者间不存在直接引用,降低了系统的耦合度
  • 方便根据需要扩展命令类即xxItem.java,符合开闭原则
相关推荐
技术小甜甜8 分钟前
【Godot】【入门】GDScript 快速上手(只讲游戏里最常用的 20% 语法)
android·游戏·编辑器·游戏引擎·godot
aqi0037 分钟前
FFmpeg开发笔记(九十五)国产的开源视频美颜工具VideoEditorForAndroid
android·ffmpeg·音视频·直播·流媒体
sanggou1 小时前
基于Java实现的简易规则引擎(日常开发难点记录)
android·java
farewell-Calm2 小时前
Android Studio 添加第三方库
android·ide·android studio
fatiaozhang95273 小时前
移动高清微型盒子1A_TBX2-2_海思MV320_安卓9_2+16G_有蓝牙没无线_优盘强刷固件包
android·电视盒子·刷机固件·机顶盒刷机·tbx2-2_海思mv320
李坤林3 小时前
Android DMA-BUF HEAP
android
TAEHENGV3 小时前
关于应用模块 Cordova 与 OpenHarmony 混合开发实战
android·javascript·数据库
程序员码歌3 小时前
短思考第265天,小红书起号3周怎么样?实操总结这3点!
android·ai编程
小徐Chao努力3 小时前
【Langchain4j-Java AI开发】05-对话记忆管理
android·java·人工智能