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. Flutter入门基础(十)- 图解修改应用名称及图标
  3. Android应用程序键盘(Keyboard)消息处理机制分析(一)
  4. 【移动生活】Google项目副总裁安迪·鲁宾谈Android
  5. 使用jQuery Mobile和Phone Gap开发Android应用程序
  6. [Android]基本概念
  7. Android(安卓)Studio(4)---开发人员工作流程基础
  8. Android盈利模式,哪种更靠谱?
  9. Android应用程序进程启动过程的源代码分析

随机推荐

  1. android 4.2修改设置菜单的背景颜色
  2. android studio查看模拟器文件夹
  3. 由Android想到的事情
  4. android 获取路径目录方法
  5. [Android随笔]Android参考书籍
  6. 推荐几本可以深入了解android系统应用开
  7. [android]android自动化测试七之动态AVD
  8. Android Studio 自动更新失败解决方法
  9. Android各层推荐开发书籍及参考资料
  10. android个人学习笔记——RatingBar