通过共享用户ID来实现多个应用程序使用同一个进程,这样也能使这些应用程序之间共享内存。
1. 同一Apk中的同一包中的多个Activity调用时进程状况验证
[1]创建Project:
project name: FirstProject
package : com.demo
默认Activity : MainActivity
[2]添加一个新的Activity:
name: SecondActivity
[3]修改布局。在MainActivity布局中添加一个Button,当点击此Button时启动SecondActivity。在SecondActivity的布局中放置一个Textview,以证明SecondActivity已启动。
[4]运行程序,查看此App进程情况:
USER:app_36 PID:8360 NAME:com.demo
[5]点击按钮,启动SecondActivity,再次查看进程情况:
USER:app_36 PID:8360 NAME:com.demo
结论:进程列表没有变化,两个Activity运行在同一进程中。
2. 同一Apk中的不同包的Activity调用时进程状况验证
[1]将SecondActivity挪到包com.demo.second中去,相应修改AndroidManifest.xml中的name为:com.demo.second.SecondActivity
[2]运行程序,查看此时进程情况:
USER:app_36 PID:10593 NAME:com.demo
[3]点击按钮启动SecondActivity,查看此时进程情况:
USER:app_36 PID:10593 NAME:com.demo
结论:进程列表没有变化,两个Activity运行在同一进程中。即进程name只受AndroidManifest.xml中manifset结点的package属性影响。
3. 同一Apk中Activity process属性修改后进程状况验证
[1]为SecondActivity添加process属性,其值为":abc",也可以随便是其他的":"开头的字符串,常见的名字是":remote":
<activity android:name="com.demo.second.SecondActivity" android:process=":abc">
</activity>
[2]运行程序,查看进程情况:
USER:app_36 PID:12137 NAME:com.demo
[3]点击按钮,启动SecondActivity,查看进程情况:
USER:app_36 PID:12137 NAME:com.demo
USER:app_36 PID:12303 NAME:com.demo:abc
结论:进程表多了一项。两个Activity各自有一个进程,SecondActivity的进程名称为 包名+后缀。
4. 不同Apk中不同包名的Activity进程状况验证
[1]运行FirstProject:
USER:app_36 PID:12137 NAME:com.demo
[2]创建SecondProject:
project name: SecondProject
package:com.demo2
默认Activity:MainActivity
[3]运行SecondProject:
USER:app_37 PID:14191 NAME:com.demo2
结论:进程表多了一项。两个Activity各自有一个进程,同时其进程用户id、包名也不同,互不影响。
5. 不同Apk,签名相同、包名相同的Activity进程状况验证
[1]修改SecondProject的包也为com.demo,相应要修改AndroidManifest.xml内容。
[2]运行SecondProject,查看进程情况:
USER:app_36 PID:14944 NAME:com.demo
结论:进程表只有一项,但是实际上FirstProject此时已经被覆盖了,系统中只存在SecondProject了,因为模拟器调试时apk使用的签名key都是一样的,系统看到key一样,包名一样认为这个包就是FirstProject所以覆盖掉了。
可以通过DDMS复制/data/system/packages.xml查看一下内容:
<package name="com.demo" codePath="/data/app/com.demo.apk" system="false" ts="1279955425000" version="1" userId="10036">
这个文件里面,package name都是唯一的,同时可以看到用户名是通过userId来决定的。
6.不同Apk,签名不相同,包名相同的Activity进程状况验证
[1]在Eclipse的Package Explorer导航树中选中FirstProject,点右键。
[2]Android tools-->Export Signed Application Package,按照向导创建一个用指定key签名的apk包。
[3]同样导出Second Project。
[4]切换窗口到模拟器,按Home键-->按Menu键-->设置-->应用程序-->管理应用程序-->SecondProject-->卸载。这是为了用命令行安装做准备。
[5]启动一个命令行窗口,执行adb install firstproject.apk,会提示成功安装。
[6]执行adb install secondproject.apk,提示安装失败。
结论:
1> 默认的Apk其安装时会分配新的UserId,即此时FirstProject以及SecondProject的UserId可以认为是不同的。
2> 包名不同,则签名key是否相同无所谓,两个apk都可以安装。【第4个实验】
3> 包名相同时,签名key相同则会覆盖【第5个实验】;签名不同则第二个apk安装会失败。【第6个实验】
7.不同Apk,Share User Id相同,包名不同时进程情况分析
[1]修改firstproject、secondproject的AndroidManifest.xml的manifset结点,增加属性
android:sharedUserId="com.demouser"
[2]修改secondproject的包为com.demo2,不然其会覆盖firsetproject。
[3]运行firsetproject、secondproject,查看进程列表:
USER:app_35 PID:19993 NAME:com.demo2
USER:app_35 PID:20045 NAME:com.demo2
结论:
仍然存在两个进程。但是进程的用户名一样,说明shareUserId确实有效了,进程pid不相同。
再次导出/data/system/packages.xml,查看其内容,可以看到两个项目的UserId都是10035,确实是一样的:
<package name="com.demo" codePath="/data/app/com.demo.apk" system="false" ts="1279957484000" version="1" sharedUserId="10035">
<package name="com.demo2" codePath="/data/app/com.demo2.apk" system="false" ts="1279957473000" version="1" sharedUserId="10035">
8.不同Apk,Share User Id相同,包名不同、指定Activity的process属性进程情况分析
[1]修改SecondProject的MainActivity的process属性,指定绑定到进程名为com.demo的进程上:
<activity android:name=".MainActivity" android:label="@string/app_name" android:process="com.demo">
[2]运行firstProject、SecondProject,查看进程情况:
USER:app_35 PID:21387 NAME:com.demo
结论:两个Activity运行于同一个进程。
9.不同Apk,Share User Id相同,包名不同、签名key不同
经实验,安装第二个apk时会提示INSTALL_FAILED_UPDATE_INCOMPATIBLE错误,安装失败。
总结:
UserId不同时:
包名不同:
未设定process属性时,各自的Activity在各自的进程。即使process指定了包名,也不会和另一个用户的同名包共享进程。
包名相同:
签名相同:覆盖旧的同包名apk。签名不同:新的apk会安装失败。【签名key一般都是不同的】
UserId相同时:
包名不同:
未设定process属性时,各自的Activity在各自的进程。process属性指定,则可以共享进程。
包名相同:
签名相同:覆盖旧的同包名apk。签名不同:新的apk会安装失败。【签名key一般都是不同的】
相关推荐
1. **进程共享**:你可以将多个Activity放入不同的进程,但通过共享用户ID,它们可以共享内存空间,减少资源消耗。 2. **数据共享**:应用可以直接访问其他具有相同共享用户ID的应用的文件,无需通过ContentProvider...
总之,Android平台提供了多种方式来实现Activity页面的切换特效,开发者可以根据需求选择适合的方法,以创造出更具吸引力和用户体验的应用。无论是简单的默认动画,还是复杂的自定义动画和过渡效果,都能让应用更加...
例如,可以让某些组件在单独的进程中运行,或者让不同应用的组件共享进程(前提是这些应用有相同的Linux用户ID并使用相同证书签名)。 Android系统会根据内存需求和组件的重要性来管理进程的生命周期。进程的重要性...
由于Android应用运行在各自独立的进程中,每个应用在安装时都会被分配一个唯一的用户ID,其数据存储在 `/data/data/应用程序包名/` 目录下,这确保了数据的安全性和隔离性。然而,为了实现跨应用的数据共享,...
但可以通过设置共享用户ID来使两个应用能够访问彼此的文件,这通常发生在需要资源共享的场景下。共享用户ID的应用会位于同一Linux进程并共享虚拟机,以节省系统资源。 【Android应用组件】 Android的核心特性之一...
1. 进程与虚拟机:在Android中,每个应用通常都在其独立的Linux进程中运行,拥有唯一的Dalvik(或ART)虚拟机和Linux用户ID。如果两个应用共享相同的Linux用户ID,它们将共用一个Linux进程和虚拟机,以提高系统效率...
总结,Android中结束进程涉及到多个层次的操作,从结束单一Activity到强制结束当前进程,再到影响其他进程。开发者应谨慎使用这些方法,避免影响用户体验和系统稳定性。在大多数情况下,让系统自动管理进程是最优...
Google 自身通过基于统一平台为用户提供信息来盈利。 Android Android Android Android 的优势 � 源代码完全开放,便于开发人员更清楚的把握实现细节,便于提高开发人员的技术水平,有利于开发 出 更具差异性的应用...
这允许组件独立运行,或者不同应用的组件共享进程(前提是这些应用具有相同的Linux用户ID并签名相同)。 5. **性能考虑** 跨进程通信相比进程内的通信更消耗资源,因此应谨慎使用。同时,过多的进程会增加系统负担...
Android应用程序的基础知识主要涵盖以下几个方面: ...综上所述,Android应用开发涉及到编程语言、安全模型、进程管理、组件交互等多个核心概念,开发者需要理解和掌握这些知识点来创建高效且安全的应用。
- 进程的生命周期从用户ID的角度来看,是在需要时启动的。这可能是因为绑定到了一个Service、Content Provider、启动了一个Activity或者触发了一个Intent Receiver。进程会持续运行,直到系统决定将其杀死,以释放...
如果Activity跨越了多个进程,系统默认的动画可能会有所不同,因为系统会处理进程间的通信。这时,开发者需要额外关注跨进程动画的实现。 10. **兼容性问题** 在不同版本的Android系统中,动画可能表现不一致。...
Android 系统中的进程优先级从高到低分为多个等级,这决定了应用的执行效率和资源分配。在 Android 应用中,主要的四大组件是 Activity、Service、BroadcastReceiver 和 ContentProvider。 Activity 是应用程序的...
总之,Android应用程序开发涉及多个层面,包括安全性、组件交互、数据共享和服务利用。开发者需要熟练掌握Java语言,理解Android框架和操作系统的工作原理,才能创建高效、安全且用户友好的应用程序。