第9章 四大组件的工作过程

2018-02-22  本文已影响0人  貌似还没想好叫什么

9.2 Activity的工作过程
启动一个activity,显示状态下,可以用过startActivity(new Intent(this,TextActivity.class))
startActivity方法有好几种重载的方法,但是他们最终会调用startActivityForResult方法。在这个方法中调用了Instrumentation的execStartActivity.在这个方法中,ActivityManagerNative.getDefault().startActivity方法实现。ActivityManagerService继承自ActivityManagerNative,而ActivityManagerNative继承自Binder并实现了IActivitymanager这个Binder接口。ActivityManagerNative具体实现是ActivityManagerService(AMS)。 在ActivityManagerNative中,AMS这个Binder对象采用单例模式对外提供,Singleton是一个单例的封装类。第一次调用他的get方法他会通过create方法来初始化AMS这个Binder对象。在后续的调用中则直接返回之前创建的对象。AMS中srtartActivity调用的ActivityStackSupervisor.startActivityMayWait方法,在startActivityMayWait中调用了startActivityLocked,然后在startActivityLocked有调用了startActivityUncheckedLocked,接着startActivityUnckeckLocked有调用了ActivityStack的resumeTopActivityLocked,resumeTopActivityLocked调用了ResumeTopActivityInnnerLocked。resumeTopActivityInnerLocked方法又调用了ActivityStackSupervistor的startSpecificActivityLocked方法。startSpecificActivityLocked方法调用了realStartActivityLocked。在ActivityStackSuporvistor中调用了app.thread.scheduleLauchActivity() 其中app.thread的类型为IApplicationThread。IApplicationThread实现者是ActivityThread中的内部类ApplicationThread。ApplicationThread继承了ApplicationThreadNative,而ApplicationThreadNative则继承了Binder并实现了IApplicationThread类。绕了一大圈Activity的启动过程最终回到了ApplicationThread中scheduleLaunchActivity来启动Activity,在ApplicationThread中schedulelaunchActivity实现很简单,就是发送了一个启动Activity的消息交由handler处理,这个Handler有一个简洁的名字H,sendMessage的作用就是发送一个消息给H处理。从Handler H对LAUNCH_ACTIVITY这个方法的处理可以知道,Activity的启动过程由ActivityThread的handleLaunchActivity方法实现,在方法中调用了performLaunchactivity方法最终完成了Activity对象的创建和启动过程,并且ActivityThread通过handleResumeActivity方法来调用被启动的Activity的onresume
这一生命周期方法

performLaunchActivity这个方法主要完成了如下几件事

1.从ActivityClientRecord中获取待启动的Activity的组件信息
2.通过Instrumentation的newActivity方法使用类加载器创建Activity类
3.通过LoadedApk的makeApplication方法尝试创建application对象
4.创建ContextImpl对象并通过Activity的attach方法来完成一些重要数据的初始化
5.调用Activity的oncreate方法

9.3Service工作原理
启动Service startService(new Intent(this,MyService.class))

Service的启动过程从ContextWrapper的startService开始。方法中调用了mBase.startService。mBase类型是ContextImpl。在ContextImpl的startService中,调用了startServiceCommon方法。而startServceCommon方法又通过ActivitymanagerNative.getDefault().startService这个对象来启动一个服务。方法中调用了(ActiveServices)mServices.startServiceLocked,此方法中有调用的startServiceInnnerLocked。此方法又调用了bringupServiceLocked,此方法中调用了realStartServiceLocked。此方法中调用了app.thread的scheduleCreateService方法来创建service对象并调用其onCreate方法。接着通过sendServiceArgsLocked方法来调用Service的其他方法,比如onStartCommand,这两个过程均是进程间通信。ApplicationThread中对Service启动过程的处理对应他的scheduleCreateService方法。方法中发送消息给Handler H来完成,H接受到这个CREATE_SERVICE消息并通过ActivityThread的handleCreateService方法来完成Service的最终启动

handleCreateService主要完成了如下几个方法

1.首先通过类加载器创建Service的实例
2.然后创建Application对象并调用其onCreate,当然Application的创建过程只会有一次
3.接着创建ContextImpl对象并通过Service的attach方法建立二者的关系
4.最后调用Service的onCreate方法并将Service方法存储在ActivityThread中的一个列表中

此外,ActivityThread还会通过handleServiceArgs方法调用Service的onStartCommand方法

9.4broadcastReceiver的工作过程

动态注册过程 ContextWrapper类的registerReciiver 然后是ConextImpl的registerReceiver方法调用了registerReceiverInternal.然后系统mPackageInfo获取IIntentReceiver对象,然后用跨进程的方式向AMS发送广播的注册请求。AMS中registerReceiver方法把InnerReceiver对象以及IntentFilter对象存储起来,这样广播就注册完成了。

广播的发送和接受
首先ContextWrapper的sendBroadcaset方法。然后调用contextImpl的sendBroadCast,向AMS调用broadcastIntent。然后调用broadcastintentLocked方法在方法内部根据intent- filter查找匹配的广播接受者,将满足条件的接受者添加到broadcastqueue。

9.5ContentProvider的工作过程

应用启动的时候,入口方法为ActivityThread的main方法,main是一个静态方法,在main方法中会创建ActivityThread的实例并创建主线程的消息队列
然后在activityThread的attach方法中远程调用AMS的attachApplication方法并将ApplicationThread对象提供给AMS。他主要作用于ActivityThread和AMS之间的通信。在AMS的attachApplication中会调用ApplicationThread的bindApplication方法。bindApplication会经过ActivityThread中的mH handler切换到ActivityThread中去,具体方法是handleBinderApplication。在方法中ActivityThread会创建Application对象并加载ContentProvider

上一篇下一篇

猜你喜欢

热点阅读