美文网首页安卓面试程序员
安卓中高级开发高频面试题之——activity 的启动流程

安卓中高级开发高频面试题之——activity 的启动流程

作者: 小饼干也有梦想 | 来源:发表于2018-12-20 14:04 被阅读21次

    这段时间整个行业都比较低迷。互联网行业在大爆发后,终于也随着2018年冬天的到来也迎来了互联网行业的冬天。很多公司都在裁员,包括BAT美团滴滴京东在内的大公司,都走过了爆发期。是该到了平稳期了,因为大爆发让公司把更多的注意力都放在了市场和盈利上,忘记了互联网的根本是服务问题。希望在平稳期,各个公司能规范行业规则,更好更优质的服务大众服务社会。

    因为大面积裁员,导致很多人在年关将近的时候,不得不重新走上求职路。我也收到了很多小伙伴发来的疑惑。其中有一个非常高频(我知道这个题非常高频,但是我自己也没有能完全详细理解并能完整的讲给大家听,所以我一直没有出这篇文章)的面试题,activity的启动流程。

    这个题真的让很多面试者都没能完美的征服面试官。不是大家不知道,也不是大家没有准备这道题。真的是这个流程如果详细说,真的非常复杂,难以完全理解;而只靠强迫记忆,还是没办法描述好。

    我相信很多人从各个地方都查过activity的启动流程:

    具体来说执行流程及方法如下:

    Intrumentation-------------->execStartActivity()

    |

    ActivityManagerProxy------>startActivity()

    |

    ActivityManagerService---->startActivity()

    |

    ActivityStackSupervisor---->startActivityMyWait()

    |

    |PackageManagerService----->resolveIntent()

    |扫描app,注册组件

    |

    ActivityStackSupervisor----->startActivityLocked()

    |

    |验证intent、Class、Permission等

    |

    |保存将要启动的Activity的Record

    |

    ActivityStackSupervisor------>startActivityUncheckedLocked()

    |

    |检查将要启动的Activity的launchMode和启动Flag

    |根据launcheMode和Flag配置task

    |

    ActvityStack--------->startActivityLocked

    |

    |任务栈历史栈配置

    |

    ActivityStack---------> resumeTopActivityInnerLocked()

    |

    |查找要进入暂停的Activity

    |

    ActivityStack---------->startPausingLocked()

    |

    |通过ipc告诉要暂停的Activity进入暂停

    |

    ActivityThread----------> handlePauseActivity()

    |

    |1正式让之前的Activity暂停

    |2 告诉AMS已经暂停完成

    |

    ActivityManagerService--------->activityPaused()

    |

    ActivityStack------------->activityPausedLocked()

    |

    ActivityStackSuperVisor------>resumeTopActivitiesLocked()

    |

    ActivityStack----------------> resumeTopActivityLocked()

    |

    |验证是否该启动的Activity所在进程和app是否存在,若存在,直接启动

    |否则,准备创建该进程

    |

    ActivityStackSuperVisor------> startSpecificActivityLocked()

    |

    |该进程不存在,创建进程

    |

    ActivityManagerService--------> startProcessLocked()

    |

    ActivityManagerService-------> startProcessLocked()

    |

    |通过Process.start(“android.app.ActivityThread”)启动进程

    |

    ActivityThread--------->main()

    |

    ActivityThread--------->attach

    |

    IActivityManager-------->attachApplication()

    |

    ActivityStackSuperVisor------> attachApplicationLocked()

    |

    |准备启动应用,先查找MainActivity

    |

    ActivityStackSuperVisor------>realStartActivityLocked()

    |

    |IPC通知ActivityThread

    |

    ActivityThread----------> scheduleLaunchActivity()

    以上就是一个应用的启动流程。我相信很多人都看过,也强迫自己记忆过。但是到了面试的时候,还是不能回答好。因为不理解这个过程,记不住。

    那么我是怎么怎么回答面试官的呢?

    首先我得承认我回答也并不完美。我知道的很难描述表达给面试官和各位。但是我抓住了面试官问这道题的初衷。其实我可以很明确的告诉你,你就是回答不正确,回答不完整,或者你把这些方法都按顺序回答正确了,面试官也不一定就觉得你回答的好。究其原因在于面试官文这个问题的初衷是考察面试人员对于安卓四层构架的理解及调用过程。说白了,如果能对安卓四层构架理解通信交互理解的多的话,这道题以及很多题交互问题都解决了。

    其实但凡安卓通信交互的,大多数(我所知道的都是)是从application层到framework层,再到libraries层,再到Linux层,然后再逆序返回来(Linux层到libraries层到framework层到application层)的一个过程。

    Activity启动也不例外,就是从application告诉framework,你用资源管理器活动管理通知管理器等等,然后再开辟资源,驱动的一些列有序的活动。(备注:这个过程非常复杂,我因为做过蓝牙和WiFi,所以大致知道蓝牙WiFi的流程,所以我会类比来说,但是理解还是不够,在这里我就不细说这个流程,我教大家一个快速记忆并且能过着一道题的方法)

    安卓四层构架图,要能画出这张图

    上图就是大家熟知的安卓四层构架,希望大家不仅能画出来四层来,还要知道每一层有哪些结构。小的方面也要能知道并且画出来。这个画出来后,这个东西知道的越多,你在安卓方面知道的也就越多(当然疑问,不知道的也会更多,我现在就感觉我自己越来越对安卓什么都不懂,什么都不会的感觉。没有了当初初生牛犊不怕虎的那种感觉了。感觉什么都要查,都要再三确认才去写。可能优化的需求和测试给我留下的烙印吧。)。

    好了回归标题,activity启动流程,如果不能自己从构架上和驱动原理上来理解,那么我给大家简单整理一下,方便你死记硬背,不至于对这个问题太窘迫。

    其实就这几个方面来记。这几个大方面记住后,具体的方法能记住几个就好了,面试官也不都记得的。你要用你的理解去明白告诉他,而不是具体的方法是什么。

    一:ActivityManagerService(ActivityManagerNative)

    ActivityManagerService(以后简称AMS):AMS是Android中最核心的服务,主要负责系统中四大组件的启动、切换、调度及应用进程的管理和调度等工作,其职责与操作系统中的进程管理和调度模块相类似,它在Android中非常重要。

    想深入了解可以参见这个链接:https://blog.csdn.net/wf_fln/article/details/78593051

    二ActivityStackSupervisor   管理整个手机任务栈

    它是栈的大管家 ActivityStackSupervisor。ActivityStackSupervisor在AMS(就上面的那个东东)中的构造方法中被创建。 

    三:ActivityStack   Activity的栈(任务栈)

    它是一个管理类,用来管理系统所有Activity的各种状态。

    四:PackageManagerService(完成组件在清单里的扫描和注册)

    它负责系统中Package的管理,应用程序的安装、卸载、信息查询等。定义了服务端和客户端通信的业务函数,还定义了内部类Stub,该类从Binder派生并实现了IPackageManager接口。因此PackageManagerService将作为服务端参与Binder通信。

    当然还有其他功能,具体可以参见这篇文章:https://www.cnblogs.com/chenlong-50954265/p/5729553.html

    五:ActivityThread(安卓java应用层的入口函数类)

    ActivitiyThread是应用程序概念空间的一个概念,他建立了应用进程运行的框架,并提供了一个IActivityThread接口作为与 Activity Manager Service的通讯接口.通过该接口AMS可以将Activity的状态变化传递到客户端的Activity对象。

    想具体了解可以参见这篇文章:https://blog.csdn.net/zhangfei2018/article/details/46518615

    六:ServiceManager

    ActiveThread是每一个应用程序所在进程的主线程,循环的消息处理

    ActiveThread与AcitivityManagerService的通信是属于进程间通信,使用binder机制

    想具体了解可以参见这篇文章:https://www.cnblogs.com/muhe221/articles/4893915.html

    好了其实整理一下,大方向主要就是这6个方面来实现activity来启动的。这6个方面必须记住。也必须知道主要有那些功能。功能我已经简化的不能再简化了。希望各位能看一下他们的具体作用然后做到心中有数(不必记住,知道你们也记不住)。

    本篇主要目的是让你短时间内记忆,了解activity的启动流程。如果想理解这个过程,可以自己查看,博主在这里推进一篇简单的博客:https://www.jianshu.com/p/2bed70245c76

    好了以上就是activity的启动流程的一些整理和我个人的理解。希望能对你有帮助。博主QQ:578161213.欢迎讨论这个问题或者技术问题。

    相关文章

      网友评论

        本文标题:安卓中高级开发高频面试题之——activity 的启动流程

        本文链接:https://www.haomeiwen.com/subject/dtsykqtx.html