Android 子Activity组件在进程内的启动过程 && 子Activity组件在新进程中的启动过程

1、子Activity组件在进程内的启动过程

在Android Activity组件的启动过程http://blog.csdn.net/jltxgcy/article/details/35984557一文中,我们已经详细分析了Activity的启动过程,对于子Activity组件在进程内的启动过程,我们只分析它们之间的不同。

主要是2处,1是不需要创建新的任务栈,2是不需要创建新进程和子线程。

第1点,体现在如下代码上:

~/Android/frameworks/base/services/java/com/android/server/am

----ActivityStack.java

public class ActivityStack {

	......

	final int startActivityUncheckedLocked(ActivityRecord r,
		   ActivityRecord sourceRecord, Uri[] grantedUriPermissions,
		   int grantedMode, boolean onlyIfNeeded, boolean doResume) {
		final Intent intent = r.intent;
		final int callingUid = r.launchedFromUid;

		int launchFlags = intent.getFlags();

		......

		if (sourceRecord == null) {
		   ......
		} else if (sourceRecord.launchMode == ActivityInfo.LAUNCH_SINGLE_INSTANCE) {
		   ......
		} else if (r.launchMode == ActivityInfo.LAUNCH_SINGLE_INSTANCE
		   ......
		}

		if (r.resultTo != null && (launchFlags&Intent.FLAG_ACTIVITY_NEW_TASK) != 0) {
		   ......
		}

		boolean addingToTask = false;
		........

		boolean newTask = false;

		// Should this be considered a new task?
		if (r.resultTo == null && !addingToTask
		   && (launchFlags&Intent.FLAG_ACTIVITY_NEW_TASK) != 0) {
			......

		} else if (sourceRecord != null) {
			......
			// An existing activity is starting this new activity, so we want
			// to keep the new one in the same task as the one that is starting
			// it.
			r.task = sourceRecord.task;
			......

		} else {
		   ......
		}

		......

		startActivityLocked(r, newTask, doResume);
		return START_SUCCESS;
	}

	......

}

第2点,体现在如下代码上,此时已经有了子Activity进程和它的子线程了。

 private final void startSpecificActivityLocked(ActivityRecord r,
            boolean andResume, boolean checkConfig) {
        // Is this activity's application already running?
        ProcessRecord app = mService.getProcessRecordLocked(r.processName,
                r.info.applicationInfo.uid);

        .....

        if (app != null && app.thread != null) {
            try {
                realStartActivityLocked(r, app, andResume, checkConfig);
                return;
            } catch (RemoteException e) {
                .....
            }

            .....
        }

        ......
}

2、子Activity组件在新进程中的启动过程

和Android Activity组件的启动过程http://blog.csdn.net/jltxgcy/article/details/35984557一文中,主要有一个区别,不需要创建新的任务栈。代码如上面所示。还需要创建新进程和子线程。

Android 子Activity组件在进程内的启动过程 && 子Activity组件在新进程中的启动过程,布布扣,bubuko.com

时间: 2024-10-21 19:54:23

Android 子Activity组件在进程内的启动过程 && 子Activity组件在新进程中的启动过程的相关文章

程序员修神之路--高并发下为什么更喜欢进程内缓存

菜菜哥,告诉你一个好消息 YY妹子,什么好消息,你有男票了? 不是啦,我做的一个网站,以前经常由于访问量太大而崩溃,现在我加上了缓存,很稳定啦 加的什么缓存呢? 我用的redis,号称业界最快的缓存组件了 你觉得现在的缓存操作应该是最快的了吗? 是的,我觉得没有缓存能比这种模式更快了 你先停停,我给你先讲个故事 进程内缓存是指缓存和应用程序在相同地址空间.即同一个进程内.分布式缓存是指缓存和应用程序位于不同进程的缓存,通常部署在不同服务器上. 从前有个机构,机构的主人叫做 CPU,这个机构专门派

Linux进程内消息总线设计

文章目录 Windows平台进程内消息总线 如果没有消息总线,会产生什么问题 死循环包含关系 高耦合.低内聚 消息总线 结构图 原理 生产者与总线的关系 总线与消费者的关系 Linux进程内消息总线设计 使用进程间实时信号来实现进程内消息总线 参考文档 整体流程 主线程注册总线消息处理函数 生产者线程产生并发送消息到总线 接收并处理消息 总线接收到消息 总线消息处理函数 消费者总线消息处理虚函数 消费者消息处理实函数 核心原理 sigqueue发送消息 sigaction处理消息 存在的问题 消

Linux环境编程之进程(四):创建新进程、执行程序和进程终止

引言: 对于每个进程,都有一个非负整数表示的唯一进程ID.虽然进程的ID是唯一的,但却是可重用的.系统中有一些专用的进程.如ID为0的进程通常是调度进程,也成交换进程或系统进程(它是内核进程).进程ID为1通常是init进程,它是一个普通的用户进程.一些与进程ID有关的函数: #include <unistd.h> pid_t getpid(void);   //返回值:调用进程的进程ID pit_t getppid(void); //返回值:调用进程的父进程ID uid_t getuid(v

从库函数fork()起步,探究新进程的诞生

本周在线学习了孟宁老师的<Linux内核分析>,本周的主要内容是进程的描述和创建,针对本次课程的实验现记录于本博文. 我们学习过操作系统这么课程,知道PCB是进程在内核中的唯一标识,PCB结构中包括本进程的全部信息.具体到Linux操作系统,这个PCB结构就是Linux内核中的task_struct结构体,该结构体非常庞大,包含了进程的很多基本信息.当我们使用fork()函数创建新进程的时候,理所当然的会涉及到task_struct函数,我们下面就从本结构体开始分析: 1235struct t

Android Service组件在进程内绑定(bindService)过程

本文参考Android应用程序绑定服务(bindService)的过程源代码分析http://blog.csdn.net/luoshengyang/article/details/6745181和<Android系统源代码情景分析>,作者罗升阳 一.Android Service组件在进程内绑定(bindService)过程 0.总图流程图如下: 1.Counter和CounterService所在应用程序主线程向ActivityManagerService进程发送BIND_SERVICE_T

Android Service组件在新进程绑定(bindService)过程

1.首先看两个例子 (1)进程内 Client端 public class CounterService extends Service implements ICounterService { ...... public class CounterBinder extends Binder { public CounterService getService() { return CounterService.this; } } ...... } Server端 public class Ma

Android Bound Service(一) ----- Extending Binder Service(进程内绑定Service的简单例子)

ref:http://developer.android.com/guide/components/bound-services.html? 前言 重新学习这一项技术,主要的原因,是因为以前没有好好的学,那时总觉得作品能动,能完成工作就好了,而这种得过且过的想法,大大地影响了我的技术程度,也因此,在这个这个博客里,有许多的复习心得.有幸得到一位前辈的指导,指出,若只是学习,而无实际应用,这样进步会较少,因此,最好要多看源码,并且自己多尝试多实践,这样学习一万小时,应该能有小进步,因此开始了 Bo

Android Service组件在新进程中的启动过程

1.startService 在Android系统匿名共享内存(Anonymous Shared Memory)Java调用接口分析,http://blog.csdn.net/jltxgcy/article/details/31414509一文,Client调用了如下代码: public class Client extends Activity implements OnClickListener { public void onCreate(Bundle savedInstanceState

COM/DCOM开发练习之进程内组件实例

作者 : 卿笃军 题目说明: 仿照例题,在其基础上实现以下功能: 1)使用C++语言实现进程内组件,组件提供复数的加.减.乘.除等计算服务:客户端部分包括录入(实部和虚部分开录入)和查询部分. 2)在VC++环境上利用ATL向导进行开发. 3)至少实现三种运行模式中的两种. 4) 程序设计风格良好,有文档注释,方法注释,语句注释.并附带说明文档. 5)下周六晚10点前统一发至我邮箱. 开工.首先编写服务器端利用ATL COM AppWizard开发出 CalcSvr.dll 第一步:打开VC++