面试之路(13)-android apk之间共享数据的方式以及shareUserId详解

本文介绍了Android应用间通过content Provider和shareUserId共享数据的方法,重点解析了shareUserId的工作原理,包括Android的App Sandbox机制,以及如何配置使两个APP运行在同一进程。同时,探讨了Android的Permission机制,特别是protectionLevel的设定及其对权限控制的影响。
摘要由CSDN通过智能技术生成

1.通过content Provider/sharedPreferrence

2.通过shareUserId

我们详细介绍一下shareUserId:

Android App Sandbox(android沙箱机制)

我们知道 Linux 中的 Sandbox 主要做隔离工作,将不同任务或用户间的耦合降到最低。Android 应用也借用了 Linux Sandbox技术,将不同 APP 之间做了隔离;APP 之间的隔离主要是资源隔离和权限访问隔离。
每个 Android APP 都运行在他们自己的 Linux 线程中(UID不同),每个应用程序彼此独立,默认情况下无法访问其他应用程序资源。 APP 权限机制为应用程序之间的资源互访提供了可行性,APP必须申请到权限并经过用户授权后才能访问 Android 系统 API 或 其他阴功程序的服务。
这里写图片描述
如果两个 Android App 运行在同一个进程里(此时的 UID 是相同的),可以共享数据和代码。

如何让两个 APP 运行在同一个进程里?

  • 首先,两个 APP 要用相同的 private key 来签名
  • 然后,添加两个APP manifest.xml 文件中属性 android:sharedUserId,均设置为相同的值或名字(其实是设置成相同的UID)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值