coreApp=true属性及android4.2下多用户进程启动说明

来源:互联网 发布:java中的replaceall 编辑:程序博客网 时间:2024/04/29 19:47

1.      关于coreApp=true的说明,在manifest中增加该属性,其实并不是代表该APP具有系统权限,而是把该类app归类为核心APP,核心app其实也是最小android framework系统。那么核心APP的作用是什么呢?在Android3.0之后,Android就增加了加密机制(可以加密机制是可选的,目前R70并没有打开),当系统开机时检测到系统加密,他就把核心APP全部启动,并显示UI提供用户输入密码,密码正确后才会启动完整系统。

android加密部分的说明可以参考下面文章;
http://blog.csdn.net/magod/article/details/7928090

 

2.      在多用户系统下,我们会看到一些进程始终只有一个,比如system_process, android系统有两种方式其他system server。

1.在init.rc启动system server,从init.rc启动的system server是永远只会有一个进程的。

 

2.通过 framework中的api启动,这个会调用的dalvik中的native code。在dalivk的native code中会在去判断请求属于system server还是普通app进程。

 

                  

普通的app,即没有增加sharedUserId="android.uid.system"属性这些,

在系统默认启动后,我们看到可能就是u0_a10,新增用户下,启动后看到的就是u10_a10。

而通过api启动的system server进程有两情况,一种就是类似init.rc的方式,只有一个进程;另外一种也会两个进程。

只有一个进程的是由什么决定的呢?有两个方面的因素:

1.必须有系统权限,即有sharedUserId="android.uid.system"属性

2.必须有android:persistent="true"属性,也就该进程常驻系统,永远不会被杀掉。

当具备上面两个属性时,即使在多用户下,启动带该属性的app,也只会有一个进程,该进程的用户为system。

Android系统可能认为,但是app常驻,同时又是系统进程,该app可能行为就和system server相同。

对这样的app,如果我们kill掉其进程,也会导致android重启,如同去杀掉了system server进程一样。

 

而在多用户下,带有system权限的app,如何启动在不同的进程呢?

其实只要app不具备android:persistent="true",就可达到该目的。

这样的app在启动后,在默认用户下,我们看到的进程用户为 system,但是在其他用户下,可能看到的用户就为u10_system。

 

原创粉丝点击