天天看点

Activity栈管理1.四大组件在AMS中存在形式2.Activity生命周期状态3.Activity管理体系4.Activity管理相关类 

AMS在系统中的作用之一就是管理四大组件,那么四大组件在AMS中必须以某种形式存在。

1.四大组件在AMS中存在形式

  1. ActivityRecord,用于描述Activity基本信息,由ActivityStackSupervison管理。
  2. ServiceRecord,描述service组件信息,由ActivityServices负责管理。
  3. BroadCastRecord,描述了应用进程的BroadCastReceiver,由BroadCastQueue管理。
  4. ContentProviderRecord,描述ContentProvider内容提供者信息,由ProviderMap管理

2.Activity生命周期状态

2.1 clien端---应用程序端:

Activity在应用端是由ActivityClientRecord来描述其生命周期的。

一个应用程序的入口是ActivityThread类,在该类中有一个内部类ApplicationThread类,它是一个binder,主要作用是应用程序和AMS进行通讯的,在ApplicationThread类中,关于生命周期的方法有:

scheduleLaunchActivity()

scheduleResumeActivity()

schedulePauseActivity()

scheduleStopActivity()

scheduleDestoryActivity()

scheduleRelaunchActivity()

scheduleWindowVisibility()

这些方法都是在Binder线程,而不是在主线程ActivityThread中,因此这些方法收到ASM消息后,会通过Handler发送对应的消息到主线程中,然后主线程中通过handler去处理对应的消息。

每一个schedule...Activity方法都会在主线程中对应一个handle...Activity方法,然后在handle...Activity方法中会根据需要进一步分解来处理,其中面向Activity的操作被统一命名为perform...Activity方法。

PS:schedule...Activity ------>handle...Activity----->perform....Activity

2.2 server端---AMS端

在AMS中,Activity的状态是由枚举类ActivityState来描述的。

INITIALIZING:正在初始化

STARTED:前台状态

RESUMED:恢复前台状态

PAUSING:正在暂停

PAUSED:暂停状态

STOPPING:正在停止

STOPPED:停止状态

FINISHING:正在移除

DESTROYING:正在销毁

DESTROYED:销毁状态

RESTARTING_PROCESS:进程重启中

3.Activity管理体系

Activity栈管理1.四大组件在AMS中存在形式2.Activity生命周期状态3.Activity管理体系4.Activity管理相关类 

4.Activity管理相关类 

4.1ActivityRecord

一个ActivityRecord描述了一个启动的Activity,一个Activity可以由于启动方式的原因存在多个ActivityRecord实例。

成员变量:

ProcessRecord app:运行在哪个进程

TaskRecord task:运行在哪个Task中

ActivityInfo info:Activity信息

Int mActivityType :Activity类型

APPLICATION_ACTIVITY_TYPE:普通应用类型

HOME_ACTIVITY_TYPE:桌面类型

RECENTS_ACTIVITY_TYPE:最近任务类型

ActivityState state:Activity状态

Int launchMode:该activity的启动模式

Int userId:act运行在哪个用户id

4.2 TaskRecord

Activity任务栈,内部维护一个ArrayList<ActivityRecord>列表,安卓把有关联的ActivityRecord会放在一个TaskRecord中。

成员变量:

ActivityStack stack:当前所属的stack

ArrayList mActivitys:当前Task中所有的activity列表

String affinity:是指root activity的affinity,该Task中第一个activity的affinity。

String mCallingPackage:调用者的包名

Int taskId:此任务的唯一标识符。

ActivityRecord mPausingActivity :正在pause

ActivityRecord mResumedActivity :已经resumed

说明:

TaskRecord 的affinity只有在其被创建的时候才有用,以后加入这个Task的Activity,即使他们通过taskAffinity指定了一个不同的字符串,也不会更改Task的名称;Activity所在的Task通过AndroidManifest.xml中<Activity>标签中的android:taskAffinity="xxx"来指定,通常不去主动设置一个Activity的taskAffinity属性,那么taskAffinity的值缺省使用包名。正因为如此,应用中所有的Activity的taskAffinity属性值默认都是相同的,都是包名,所以在应用中使用FLAG_ACTIVITY_NEW_TASK标志去启动一个本应用中的一个Activity,也不会创建一个新的task,除非这个Activity 额外指定了不同的taskAffinity属性值;

4.3 ActivityStack

充当TaskRecord的管理者角色,由多个或一个TaskRecord序列组成。

成员变量:

ArrayList<TaskRecord> mTaskHistory:保存所有的TaskRecord

ArrayList<ActivityRecord> mLRUActivites:最近活动的ActivityRecord;

Int mstackId:ActivityStack的唯一标识

ActivityStackSupervisor mStackSupervisor:ActivityStack的管理者

ActivityStack mHomeStack :桌面的stack

ActivityStack mFocusedStack :当前聚焦stack

ActivityStack mLastFocusedStack :正在切换

ActivityContainer mActivityContainer :ActivityStack的容器类,它负责描述ActivityStack,包括其StackId、所属Display、容器状态等。ActivityContainer继承自IActivityContainer.Stub,支持binder调用,显而易见的是,它与其负责描述ActivityStack是一对一关系。\

PS:

对于主屏也就是DEFAULT_DISPLAY默认屏幕来说,其一般拥有两个ActivityStack:其一为此处创建的HomeStack,主要负责管理Launcher中的安卓桌面和SystemUI中的最近任务列表;另一个就是管理其他应用Activity的NormalStack。这两种Stack及其内容我们可以通过命令dumpsys activity activities查看。

HomeStack与NormalStack本质上都是ActivityStack,此处是基于其功能上的不同才将这两种ActivityStack分别命名。

安卓系统启动后首先显示的是存放于HomeStack的安卓桌面Launcher,所以ASS在启动时就会将HomeStack初始化,并将其记录为焦点Stack。

​​​​​​​4.4 ActivityStackSupervison

ActivityStackSupervisor 用于管理ActivityStack;ActivityStackSupervisor为AMS提供管理方法;管理着系统中的三个ActivityStack;

ActivityStack mHomeStack //桌面的stack

ActivityStack mFocusedStack //当前聚焦stack

ActivityStack mLastFocusedStack //正在切换

AMS使用mHomeStack,mFocusedStack来完成系统全部的Activity的管理和调度。其中mHomeStack管理的是Launcher相关的任务,包括Launcher、RecentTask,Keyguad,除了上述以外的任务都归mFocusedStack管理。

AMS 通过操作ActivityStackSupervisor来管理Activity;具体是如何操作的呢?ActivityStackSupervisor通过ActivityContainer来管理ActivityStack(ActivityStack的构造方法只有在ActivityContainer的构造方法中被调用),ActivityContainer关联ActivityDisplay,ActivityDisplay将自己的mStacks赋值给ActivityContainer的mStack;mStack.mStacks = activityDisplay.mStacks;

ActivityContainer在ActivitySupervisor的createStackOnDisplay中被初始化,createStackOnDisplay在setWindowManager或adjustStackFocus或restoreRecentTaskLocked中被调用;这里说说从setWindowManager开始的调用流程,setWindowManager在SystemServer启动AMS时调用,然后调用ActivityContainer.attachToDisplayLocked方法;流程的大概就是根据mDisplayId获取ActivityDisplay,将ActivityDisplay的mStacks(代表该Display上的所有activitystack) 赋值给ActivityContainer的mStack的mStacks;同时将调用activityDisplay.attachActivities(mStack)将ActivityContainer的mStack(ActivityContainer维护的ActivityStack)添加到ActivityDisplay的mStacks 中;