Android是基于Linux的OS,Linux下有一套自己的账户管理体系,而Android对此有一些封装和改动。同事,Android也引进了自己的多用户功能。所以,大量的类似“uid”的概念存在于Android中,让初学者很头痛,有必要整理一下以释疑。

1.Linux uid/gid
Linux下的用户id(uid)和群组id(gid)。Linux是多用户系统,每个用户都拥有一个uid,这个uid由系统和用户名做映射绑定。同时,为了便于用户管理(譬如管理文档权限),Linux引入了群组的概念,可以将多个用户归于一个群组。每一个群组拥有一个群组id(gid)。
root用户:Linux下的唯一的超级用户,拥有所有的系统权限。root用户所在的组即root组。

2.Android uid/gid(Linux uid/gid的移花接木)
在Android 4.2之前,Android不支持多用户。Android将Linux的账户管理体系用在了应用管理上。举例说明,在一台android手机上安装某应用,通过adb shell查看其数据文档:

可以看到文件拥有者是u0_a81,所在群组为u0_a81。从data/system/packages.xml根据包名查看此应用信息,可以看到:userId=”10081”。
在代码中通过接口android.os.Process.myUid()来获取,也可以看到10081。
从Android源代码Process.java对于此Api的注释来看:

可以看到应用进程是运行在这个Linux kernel uid下面。
在Process源代码中还能够看到一些常量定义:

可以看到,Android对于一些系统uid的保留定义,而且基本上每个用户自成一群组,gid与uid相同。群组的概念已经被淡化。查看某一个系统应用data/data/目录,可以看到:

拥有者为system,群组为system。结合上面的u0_a81,可以看到,Android会以应用为单位,分配uid/gid。这里的system、u0_a81是用户名/群组名,由android生成,与uid/gid映射匹配。
分析到这,不难理解AndroidManifest.xml中的sharedUserId属性,譬如,前面举例说明的系统应用Settings,其AndroidManifest.xml中即有

即,Android为应用准备的uid/gid是可以共享的,其目的当然包括这样可以在不同的应用中共享数据和文件。当然,这还需要应用之间的签名匹配。

更多相关文章

  1. Android应用程序注册广播接收器(registerReceiver)的过程分析
  2. Android(安卓)应用(中英文)切换
  3. Android高级开发第三讲--应用程序基础
  4. 工(程师)欲善其事,必先利其(编译)器——《Android(安卓)Studio实战—
  5. Android应用程序进程启动过程的源代码分析
  6. Android(安卓)开发简介-系统架构
  7. Android开发应用记录
  8. Android输出Log相关应用技巧剖析
  9. 关于移动开发,再推荐给你5本

随机推荐

  1. Oracle数据科学公开课(1):OCI基础
  2. Java常见排序算法之插入排序
  3. PowerDesigner教程和视频
  4. 小白如何入门Mybatis?这里有答案
  5. 【4.5-4.11】上周精彩回顾
  6. hbase 学习
  7. 邮件加密的第三道坎是密钥管理
  8. 前端js是什么意思?
  9. Photoshop Elements:做出完美大合照,让笑容
  10. 我用注解实现了优雅的跨库查询,架构师竖起