- 浏览: 23765 次
- 性别:
- 来自: 北京
最新评论
page4
在这里我们分析一下ContextImpl的init函数的具体实现:
final void init(LoadedApk packageInfo, IBinder activityToken, ActivityThread mainThread) {
init(packageInfo, activityToken, mainThread, null, null, Process.myUserHandle());
}
1 final void init(LoadedApk packageInfo, IBinder activityToken, ActivityThread mainThread,
2 Resources container, String basePackageName, UserHandle user) {
3 mPackageInfo = packageInfo;
4 mBasePackageName = basePackageName != null ? basePackageName : packageInfo.mPackageName;
5 mResources = mPackageInfo.getResources(mainThread);
6
7 if (mResources != null && container != null
8 && container.getCompatibilityInfo().applicationScale !=
9 mResources.getCompatibilityInfo().applicationScale) {
10 if (DEBUG) {
11 Log.d(TAG, "loaded context has different scaling. Using container's" +
12 " compatiblity info:" + container.getDisplayMetrics());
13 }
14 mResources = mainThread.getTopLevelResources(
15 mPackageInfo.getResDir(), Display.DEFAULT_DISPLAY,
16 null, container.getCompatibilityInfo());
17 }
18 mMainThread = mainThread;
19 mActivityToken = activityToken;
20 mContentResolver = new ApplicationContentResolver(this, mainThread, user);
21 mUser = user;
22 }
init函数的主要逻辑就是初始化主要的成员变量
page5
activity的attach函数的定义如下, 注意下面是两个函数:
1 final void attach(Context context, ActivityThread aThread, Instrumentation instr, IBinder token,
2 Application application, Intent intent, ActivityInfo info, CharSequence title,
3 Activity parent, String id, NonConfigurationInstances lastNonConfigurationInstances,
4 Configuration config) {
5 attach(context, aThread, instr, token, 0, application, intent, info, title, parent, id,
6 lastNonConfigurationInstances, config);
7 }
8
9 final void attach(Context context, ActivityThread aThread,
10 Instrumentation instr, IBinder token, int ident,
11 Application application, Intent intent, ActivityInfo info,
12 CharSequence title, Activity parent, String id,
13 NonConfigurationInstances lastNonConfigurationInstances,
14 Configuration config) {
15 attachBaseContext(context);
16
17 mFragments.attachActivity(this, mContainer, null);
18
19 mWindow = PolicyManager.makeNewWindow(this);
20 mWindow.setCallback(this);
21 mWindow.getLayoutInflater().setPrivateFactory(this);
22 if (info.softInputMode != WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPECIFIED) {
23 mWindow.setSoftInputMode(info.softInputMode);
24 }
25 if (info.uiOptions != 0) {
26 mWindow.setUiOptions(info.uiOptions);
27 }
28 mUiThread = Thread.currentThread();
29
30 mMainThread = aThread;
31 mInstrumentation = instr;
32 mToken = token;
33 mIdent = ident;
34 mApplication = application;
35 mIntent = intent;
36 mComponent = intent.getComponent();
37 mActivityInfo = info;
38 mTitle = title;
39 mParent = parent;
40 mEmbeddedID = id;
41 mLastNonConfigurationInstances = lastNonConfigurationInstances;
42
43 mWindow.setWindowManager(
44 (WindowManager)context.getSystemService(Context.WINDOW_SERVICE),
45 mToken, mComponent.flattenToString(),
46 (info.flags & ActivityInfo.FLAG_HARDWARE_ACCELERATED) != 0);
47 if (mParent != null) {
48 mWindow.setContainer(mParent.getWindow());
49 }
50 mWindowManager = mWindow.getWindowManager();
51 mCurrentConfig = config;
52 }
第15行(Activity->attach)调用attachBaseContext函数, 关于attachBaseContext函数的详细分析可以参考page6文件.
调用完attachBaseContext函数我们明白了, Activity拿着ContextImpl, 而ContextImpl也拿着这个Activity
page6
在这篇文章里, 我们分析一下Activity的attachBaseContext函数的具体逻辑, 其实attachBaseContext函数是从Activity的父类ContextThemeWrapper继承而来的,
我们先来看一下ContextThemeWrapper类的继承体系,
public class ContextThemeWrapper extends ContextWrapper
public class ContextWrapper extends Context
那么ContextThemeWrapper的attachBaseContext函数的具体实现如下:
1 @Override protected void attachBaseContext(Context newBase) {
2 super.attachBaseContext(newBase);
3 mBase = newBase;
4 }
第2行(ContextThemeWrapper->attachBaseContext)调用父类ContextWrapper的attachBaseContext函数:
1 protected void attachBaseContext(Context base) {
2 if (mBase != null) {
3 throw new IllegalStateException("Base context already set");
4 }
5 mBase = base;
6 }
ContextWrapper的attachBaseContext函数会设置成员变量mBase, 使之指向一个Context对象, 也就是ContextImpl了.
ContextWrapper的成员变量mBase的定义如下:
Context mBase;
第3行(ContextThemeWrapper->attachBaseContext)又会初始化成员变量mBase, 我靠!咋又有一个!
ContextThemeWrapper的mBase的定义如下:
private Context mBase;
在这里我们分析一下ContextImpl的init函数的具体实现:
final void init(LoadedApk packageInfo, IBinder activityToken, ActivityThread mainThread) {
init(packageInfo, activityToken, mainThread, null, null, Process.myUserHandle());
}
1 final void init(LoadedApk packageInfo, IBinder activityToken, ActivityThread mainThread,
2 Resources container, String basePackageName, UserHandle user) {
3 mPackageInfo = packageInfo;
4 mBasePackageName = basePackageName != null ? basePackageName : packageInfo.mPackageName;
5 mResources = mPackageInfo.getResources(mainThread);
6
7 if (mResources != null && container != null
8 && container.getCompatibilityInfo().applicationScale !=
9 mResources.getCompatibilityInfo().applicationScale) {
10 if (DEBUG) {
11 Log.d(TAG, "loaded context has different scaling. Using container's" +
12 " compatiblity info:" + container.getDisplayMetrics());
13 }
14 mResources = mainThread.getTopLevelResources(
15 mPackageInfo.getResDir(), Display.DEFAULT_DISPLAY,
16 null, container.getCompatibilityInfo());
17 }
18 mMainThread = mainThread;
19 mActivityToken = activityToken;
20 mContentResolver = new ApplicationContentResolver(this, mainThread, user);
21 mUser = user;
22 }
init函数的主要逻辑就是初始化主要的成员变量
page5
activity的attach函数的定义如下, 注意下面是两个函数:
1 final void attach(Context context, ActivityThread aThread, Instrumentation instr, IBinder token,
2 Application application, Intent intent, ActivityInfo info, CharSequence title,
3 Activity parent, String id, NonConfigurationInstances lastNonConfigurationInstances,
4 Configuration config) {
5 attach(context, aThread, instr, token, 0, application, intent, info, title, parent, id,
6 lastNonConfigurationInstances, config);
7 }
8
9 final void attach(Context context, ActivityThread aThread,
10 Instrumentation instr, IBinder token, int ident,
11 Application application, Intent intent, ActivityInfo info,
12 CharSequence title, Activity parent, String id,
13 NonConfigurationInstances lastNonConfigurationInstances,
14 Configuration config) {
15 attachBaseContext(context);
16
17 mFragments.attachActivity(this, mContainer, null);
18
19 mWindow = PolicyManager.makeNewWindow(this);
20 mWindow.setCallback(this);
21 mWindow.getLayoutInflater().setPrivateFactory(this);
22 if (info.softInputMode != WindowManager.LayoutParams.SOFT_INPUT_STATE_UNSPECIFIED) {
23 mWindow.setSoftInputMode(info.softInputMode);
24 }
25 if (info.uiOptions != 0) {
26 mWindow.setUiOptions(info.uiOptions);
27 }
28 mUiThread = Thread.currentThread();
29
30 mMainThread = aThread;
31 mInstrumentation = instr;
32 mToken = token;
33 mIdent = ident;
34 mApplication = application;
35 mIntent = intent;
36 mComponent = intent.getComponent();
37 mActivityInfo = info;
38 mTitle = title;
39 mParent = parent;
40 mEmbeddedID = id;
41 mLastNonConfigurationInstances = lastNonConfigurationInstances;
42
43 mWindow.setWindowManager(
44 (WindowManager)context.getSystemService(Context.WINDOW_SERVICE),
45 mToken, mComponent.flattenToString(),
46 (info.flags & ActivityInfo.FLAG_HARDWARE_ACCELERATED) != 0);
47 if (mParent != null) {
48 mWindow.setContainer(mParent.getWindow());
49 }
50 mWindowManager = mWindow.getWindowManager();
51 mCurrentConfig = config;
52 }
第15行(Activity->attach)调用attachBaseContext函数, 关于attachBaseContext函数的详细分析可以参考page6文件.
调用完attachBaseContext函数我们明白了, Activity拿着ContextImpl, 而ContextImpl也拿着这个Activity
page6
在这篇文章里, 我们分析一下Activity的attachBaseContext函数的具体逻辑, 其实attachBaseContext函数是从Activity的父类ContextThemeWrapper继承而来的,
我们先来看一下ContextThemeWrapper类的继承体系,
public class ContextThemeWrapper extends ContextWrapper
public class ContextWrapper extends Context
那么ContextThemeWrapper的attachBaseContext函数的具体实现如下:
1 @Override protected void attachBaseContext(Context newBase) {
2 super.attachBaseContext(newBase);
3 mBase = newBase;
4 }
第2行(ContextThemeWrapper->attachBaseContext)调用父类ContextWrapper的attachBaseContext函数:
1 protected void attachBaseContext(Context base) {
2 if (mBase != null) {
3 throw new IllegalStateException("Base context already set");
4 }
5 mBase = base;
6 }
ContextWrapper的attachBaseContext函数会设置成员变量mBase, 使之指向一个Context对象, 也就是ContextImpl了.
ContextWrapper的成员变量mBase的定义如下:
Context mBase;
第3行(ContextThemeWrapper->attachBaseContext)又会初始化成员变量mBase, 我靠!咋又有一个!
ContextThemeWrapper的mBase的定义如下:
private Context mBase;
发表评论
-
Activity与WindowManagerService连接的过程(三)
2018-04-16 16:27 622page11 WindowManagerService ... -
Activity与WindowManagerService连接的过程(二)
2018-04-16 16:36 763page6 WindowManagerGlobal的getW ... -
Activity与WindowManagerService连接的过程(一)
2018-04-16 16:21 984page1 Activity组件在 ... -
Activity的ViewRoot的创建过程(三)
2017-11-06 14:25 739page7 在这篇文章里, 我们分析一下W类的构造过程. W ... -
Activity的ViewRoot的创建过程(二)
2017-11-06 14:29 937page4 我们看一下ViewRootImpl对象的创 ... -
Activity的ViewRoot的创建过程(一)
2017-11-06 14:27 1078page1 当一个Activity第一次激活的时候会为该Ac ... -
Activity的Window和WindowManager的创建过程(三)
2017-07-05 11:49 1334page9 在这里我们分析一下DisplayManager的 ... -
Activity的Window和WindowManager的创建过程(二)
2017-07-05 11:31 543page5 在这篇文章中, 我们分析一下ContextImp ... -
Activity的Window和WindowManager的创建过程(一)
2017-07-05 11:27 605page1 我们开始分析一下Activity的Window和 ... -
Acitivy创建Context的过程(一)
2017-06-21 14:15 635page1 从本篇文章开始,我们分析一下Activity创建 ... -
应用程序进程与SurfaceFlinger的连接过程
2017-06-21 11:49 1056我们从SurfaceComposerClient对象的创建开始 ... -
Android源码之SurfaceFlinger的启动(三)
2017-04-20 11:09 1041page11 我们来看一下SurfaceFlinger ... -
Android源码之SurfaceFlinger的启动(二)
2017-04-18 15:15 870page6 我们看一下Thread的run函数的实现: ... -
Android源码之SurfaceFlinger的启动(一)
2017-04-17 10:07 994page1 在Android系统中, 显示系统在底层是通过S ... -
Android源码之Zygote
2015-12-15 11:45 516当ActivityManagerService启动一个应用程序 ... -
Android源码之Binder(五)
2015-12-04 09:19 1507Service组件在启动时,需要将自己注册到Service M ... -
Android源码之Binder(四)
2015-12-04 09:18 1922case BINDER_SET_MAX_THREADS: ... -
Android源码之Binder(三)
2015-12-04 09:17 909{ int ret; struct binder_pr ... -
Android源码之Binder(二)
2015-12-04 09:15 546分析完Binder驱动程序的打开和内存分配的过程之后,我们看一 ... -
Android源码之Binder(一)
2015-12-04 09:12 993在Android系统中,进程间通信使用的是Binder机制。B ...
相关推荐
首先系统的服务会先检查startActivity中的intent的信息,然后在去创建进程,最后才是执行启动Acitivy的操作。而我们上面提到的显示白黑屏的问题,就是在这段时间内产生的。 系统在绘制页面加载布局之前,首先会初始...
在做Service简单练习时,在Service中的OnCreate、OnStart、OnDestroy三个方法中都像在Activity中同样的方法调用了Toast.makeText,并在Acitivy中通过两个按钮来调用该服务的onStart和onDestroy方法: DemoService...
数学建模拟合与插值.ppt
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
mysql相关资源.txt
此项目为一个HTML+CSS+JS的国漫分享网站,用户可以在此网站中观看自己喜欢的国漫。此网站共有4个页面,分别为首页,最新动态,热门推荐,分类。页面动漫图片齐全,内容可更改。可用于期末课程设计或个人课程设计。
Python爬虫爬取漫画
模拟退火算法应用。C++语言编程用模拟退火算法解决旅行商问题。该资源包含模拟退火算法C++语言的源代码。模拟退火算法是一种基于概率的全局优化算法,最初来自于物理学中的退火过程。它通过模拟金属冷却时原子排列逐渐趋于最低能量状态的过程来寻找问题的最优解。模拟退火算法常用于解决非线性、组合优化问题,特别适合于大规模、复杂的搜索空间。
传感器试题及答案.doc
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
本文档主要讲述的是MongoDB数据表基本操作;希望对大家会有帮助;感兴趣的朋友可以过来看看
本数据集提供了2011至2021年间全国各省废气和废水中主要污染物的排放量统计数据。数据涵盖了二氧化硫、氮氧化物、烟尘和颗粒物等关键污染物的排放量,为研究中国环境状况和污染物排放趋势提供了宝贵信息。数据显示,2011-2021年间,各省的二氧化硫排放量从数十万吨到数百万吨不等,其中广东、广西、海南等省份的排放量较高。氮氧化物排放量同样显示出地域差异,北京、天津等北方城市的排放量相对较低,而一些工业大省如河北、山西的排放量较高。颗粒物排放量统计显示,工业源和生活源是主要的排放源,其中工业源排放量占比较大。这些数据不仅对环保政策制定者具有参考价值,也为学术研究提供了实证基础。
脉冲宽度测量单片机课程设计.doc
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
全国矢量地图数据【国道+高速公路】ArcGIS Shape格式数据集是一种专门用于地理信息系统(GIS)的矢量数据集,包含中国范围内国道和高速公路的详细路网信息。该数据集广泛应用于交通规划、导航、物流分析和灾害应急等领域,具有高精度和易用性。 数据集特点: 1. 数据内容: 国道:包括以“G”开头的国家级公路,如G1京哈高速、G107国道等。 高速公路:包括全国范围内的所有高速公路网,覆盖主要经济区、城市和边境口岸。 属性数据: 道路编号(国道或高速公路编号)。 道路名称。 道路等级(如一级、二级、快速路等)。 起点和终点坐标。 道路长度(单位:公里)。 相关属性(如路段建成年份、设计速度、车道数等)。 2. 数据格式: **Shapefile(.shp)**格式,支持主流GIS软件(如ArcGIS、QGIS)及数据处理工具(如Python、Matlab)。 3. 投影坐标系: 一般采用WGS84地理坐标系,或可根据需求转换为**GCJ-02(火星坐标系)**以配合国内导航应用。
4
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、python、web、C#、EDA、proteus、RTOS等项目的源码。【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。
Oracle从8.1.6开始提供分析函数,分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是对于每个组返回多行,而聚合函数对于每个组只返回一行。 感兴趣的朋友可以过来看看