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(安卓)技术体系
  2. 浅入浅出 Android(安卓)安全:第一章 Android
  3. Android外文翻译系列 - Android应用程序应该是什么样的?
  4. 如何使用Android(安卓)SDK开发Android应用?
  5. 手机和平板之外——带你理解跨设备的Android(安卓)技术体系
  6. 新书内容连载(3):Android(安卓)SDK中常用命令行工具(一)
  7. 新书内容连载(3):Android(安卓)SDK中常用命令行工具(一)
  8. 新书内容连载(3):Android(安卓)SDK中常用命令行工具(一)
  9. 什么是android(What Is Android?)

随机推荐

  1. Android客户端和Java服务器端集成支付宝
  2. Android小项目之--前台界面与用户交互的
  3. Android(安卓)仪表进度条 自定义View
  4. Android必知必会-Android(安卓)Studio修
  5. Android阻塞式确认Dialog-Loop实现方式
  6. Android(安卓)开发者 for Flutter (2)如何
  7. Android应用程序权限机制的源代码分析(1)
  8. Nokia同意放人 移交125名Qt核心成员给Dig
  9. android单向无限循环的轮播图效果。
  10. Google 或强制 OEM 预装 20 款应用,给你一