博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android Core
阅读量:5312 次
发布时间:2019-06-14

本文共 5170 字,大约阅读时间需要 17 分钟。

 

 

内容概要

• Activity的继承关系

• Android 中 Context介绍 • Acitivy实际是如何实例化的 • Activity生命周期 • Activity的启动方式,Task&Back Stack,进 程和线程,Intent.FLAG_ACTIVITY*

• Activity,Window,View的关系

• Android消息

 

内容

 

Activity是什么

• 是个应用程序的组件,提供⼀一个可以让用户 交互的屏幕。它本身并不是界面。

Activity的继承关系

• java.lang.Object • ↳ android.content.Context • ↳ android.content.ContextWrapper • ↳ android.view.ContextThemeWrapper • ↳ android.app.Activity

 

Android 中 Context

• 是Android应用程序环境的全局信息的接 口。 • 中文翻译是:上下文 • 可以理解为:句柄,环境变量。 Context是什么,它的作用? • Context字面意思上下文,位于framework package的android.content.Context中,其实 该类为LONG型,类似Win32中的Handle句 柄,很多方法需要通过Context才能识别调用 者的实例,比如说T oast的第⼀一个参数就 是Context,⼀一般在Activity中我们直接 用this代替,代表调用者的实例为Activity,而 到了⼀一个button的onClick(View view)等方法 时,我们用this时就会报错,所以我们可能使 用ActivityName.this来解决,主要原因是因为 实现Context的类主要有Android特有的几个模 型,Activity、Service以及BroadcastReceiver

 

Activity生命周期 • 1、Activity 从创建到进入运行态所触发的事 件 onCreate()-->onStart-->onResume() • 2、从运行态到停止态所触发的事件 onPause()--->onStop() • 3、从停止态到运行态所触发事件 onRestart()-->onStart()--->onResume() • 4、从运行态到暂停态所触发事件 onPause() • 5、从暂停态到运行态所触发事件 onResume() Activity生命周期 • a.打开应 用:onCreate-》onStart-》 onResume ,在开始的时候这三个方法都会调用。 • b.从第⼀一个activity切换到第二个:先 会 onPause第⼀一个,然 后onCreate-》onStart-》 onResume,最 后在onStop • c.从第二个切换到第⼀一个:内容与上⼀一步 相同 • d.按手机的回退(back)键:先onPause 第⼀一个,然 后 onRestart-》 onStart-》 onResume

 

 

 

Activity的启动方式

• Activity有四种加载模式:

 

• Standard • singleTop • singleTask • singleInstance Activity的启动方式 • Standard启动⼀一次就⼀一个实例 • singleTop 启动时,如果正好在顶部 则NewIntent到这个实例,如果不在,则是 第二个实例 • singleTask 当Task里存在实例, 则NewIntent到这个实例, • singleInstance创建⼀一个单独的task存放这 个实例,每次跳过来都是这个实例。 • onNewIntent onStart onResume FLAG_ACTIVITY_REORDER_TO • 如果已经启动了四 个Activity:A,B,C和D, 在D Activity里,想再启动⼀一个Actvity B, 但不变成A,B,C,D,B,而是希望 是A,C,D,B,则可以像下面写代 码:intent.addFlags(Intent.FLAG_ACTIVI TY_REORDER_TO_FRONT);  FLAG_ACTIVITY_NEW_TASK • 例如现在栈1的情况是:A B C。C通 过intent跳转到D,并且这个intent添加 了FLAG_ACTIVITY_NEW_TASK标记,如 果D这个Activity在Manifest.xml中的声明中 添加了Task affinity,并且和栈1的affinity不 同,系统首先会查找有没有 和D的T askaffinity相同的task栈存在,如果 有存在,将D压入那个栈,如果不存在则会 新建⼀一个D的affinity的栈将其压入。如 果D的Task affinity默认没有设置,或者和 栈1的affinity相同,则会把其压入栈1,变 成:A B C D,这样就和不 FLAG_ACTIVITY_NO_HISTORY FLAG_ACTIVITY_SINGLE_TOP • 例如现在栈情况为:A B C。C通过intent跳 转到D,这个intent添 加FLAG_ACTIVITY_NO_HISTORY标志, 则此时界面显示D的内容,但是它并不会压 入栈中。如果按返回键,返回到C,栈的情 况还是:A B C。如果此时D中又跳转到E, 栈的情况变为:A B C E,此时按返回键会 回到C,因为D根本就没有被压入栈中。 • FLAG_ACTIVITY_SINGLE_TOP:和上 面Activity的Launch mode的singleTop类 似。如果某个intent添加了这个标志,并且 这个intent的目标activity就是栈顶 FLAG_ACTIVITY_SINGLE_TOP • 如果已经启动了四个Activity:A,B, C和D。在D 里,要到B ,同时去掉 C D 。用:Intent.FLAG_ACTIVITY_CLEAR_T OP • 如果不想重新再创建⼀一个新的B,则加 上:Intent.FLAG_ACTIVITY_SINGLE • intent.setFlags(Intent.FLAG_ACTIVITY_SI NGLE_TOP |Intent.FLAG_ACTIVITY_CLEAR_TOP);

• 这个和singleTask方式差不多

 

 

Android的5个进程等级

• 1) Foreground Process • 正处于Activity Resume() 状态 • 正处于与bound服务交互的状态 • 正处于服务在前台运行的状态 , (startForeground() 被调用) • Service生命周期函数正在被执行 ( onCreate() , onStart() , onDestroy()) • BroadcastReceiver 正在执 行onReceive()方法 杀死Foreground Process 需要用户响应

 

 

程序启动



PackManager和ActivityManager

 

一、PackageManager相关 PackageManager相关 本类API是对所有基于加载信息的数据结 构的封装,包括以下功能: • 安装,卸载应用 查询permission相关信息 查询Application相关信 息(application,activity,receiver,service ,provider及相应属性等) 查询已安装应用 增加,删除permission 清除用户数据、缓存,代码段等

 

Launcher

• 系统启动后加载的第⼀一个程序 • 是其他应用程序的入口 • HomeScreen

 

 

 

Activity,Window,View的关系

• Activity在onCreate之前调用attach方法, 在attach方法中会创建window对 象。window对象创建时并木有创 建Decor对象对象。用户在Activity中调 用setContentView,然后调 用window的setContentView,这时会检 查DecorView是否存在,如果不存在则创 建DecorView对象,然后把用户自己 的View 添加到DecorView中。

 

 

Android消息

• 关于消息机制的几个类 • Handler • Message • MessageQueue • Looper Android消息 • 1.Looper:(相当于隧道) ⼀一个线程可以产生 ⼀一个Looper 对象,由它来管理此线程里 的Message Queue( 车队,消息隧道) 。 • 2.Handler: 你可以构造Handler 对象来 与Looper 沟通,以便push 新消息 到Message Queue 里;或者接 收Looper( 从Message Queue 取出) 所送 来的消息。 • 3. Message Queue( 消息队列): 用来存放线 程放入的消息。 • 4 .线程:UI thread 通常就是main thread ,而Android 启动程序时会替它建立

Activity实际是如何实例化的

activity  and  binder

• 从宏观的角度观 察Binder,Service,Service Manager,并阐 述各自的概念。从Linux的概念空间 中,Android的设计Activity托管在不同的的 进程,Service也都是托管在不同的进程, 不同进程间的Activity,Service之间要交换数 据属于IPC。Binder就是为了Activity通讯而 设计的⼀一个轻量级的IPC框架。 • activity 整个应用程序的启动过程: • ⼀一. Step1 - Step 11:Launcher通 过Binder进程间通信机制通

Activity调用栈

• 0:dalvik.system.VMStack.getThreadStack Trace(Native 1:java.lang.Thread.getStackTrace(Thread .java:737) • 2:app.android.demo.activity.MainTestActiv ity$1.run(MainTestActivity.java:40) 3:android.os.Handler.handleCallback(Han dler.java:587) • 4:android.os.Handler.dispatchMessage(H andler.java:92) • 5:android.os.Looper.loop(Looper.java:123 ) • • • • • • • Activity调用栈
• 每个应用程序都以ActivityThread.main()为 入口进入到消息循环处理。对于⼀一个进程 来讲,我们需要这个闭合的处理框架。 

Activity与HistoryRecord的关系

• 在整个系统中,Activity实际上有两个实 体。⼀一个在应用进程中跟应用程序员打交 道的Activity,⼀一个是在AMS的中具有管理 功能的History Record。应用进程中 的Activity都登记ActivityThread实例中 的mActivity数组中,而 在AM端,HistroytRecord实例放置 在mHistroy栈中。mHistory栈是Android管 理Activity的场所,放置在栈顶的就 是User看到的处于活动状态的Activity。 • Activity与HistrotyRecord的关系图可以表示 如下: 

 

转载于:https://www.cnblogs.com/fenglh/p/3512072.html

你可能感兴趣的文章
shell习题第16题:查用户
查看>>
python脚本检查TCP端口是否正常
查看>>
梯度下降法与方向导数
查看>>
实验4 [bx]和loop的使用
查看>>
Redis常用命令
查看>>
Handler消息传递机制
查看>>
linux 查看系统信息
查看>>
2018.08.22 NOIP模拟 shop(lower_bound+前缀和预处理)
查看>>
2018.11.06 bzoj1040: [ZJOI2008]骑士(树形dp)
查看>>
2019.02.15 bzoj5210: 最大连通子块和(链分治+ddp)
查看>>
redis cluster 集群资料
查看>>
Junit使用教程(一)
查看>>
Python接口测试-使用requests模块发送post请求
查看>>
混合模式程序集是针对“v2.0.50727”版的运行时生成的,在没有配置其他信息的情况下,无法在 4.0 运行时中加载该程序集。...
查看>>
jQuery总结或者锋利的jQuery笔记二
查看>>
前后端协作--服务器渲染与前后端分离
查看>>
微软职位内部推荐-Sr. SE - Office incubation
查看>>
微软职位内部推荐-SOFTWARE ENGINEER II
查看>>
GDB调试
查看>>
centos系统python2.7更新到3.5
查看>>