6.ContentProvider实现原理
ContentProvider 有以下两个特点:
- 封装:对数据进行封装,提供统一的接口,使用者完全不必关心这些数据是在DB,XML、Preferences或者网络请求来的。当项目需求要改变数据来源时,使用我们的地方完全不需要修改。
- 提供一种跨进程数据共享的方式。
Content Provider组件在不同应用程序之间传输数据是基于匿名共享内存机制来实现的。其主要的调用过程:
①通过ContentResolver先查找对应给定Uri的ContentProvider,返回对应的BinderProxy
-
如果该Provider尚未被调用进程使用过:
-
通过ServiceManager查找activity service得到ActivityManagerService对应BinderProxy
-
调用BinderProxy的transcat方法发送GET_CONTENT_PROVIDER_TRANSACTION命令,得到对应ContentProvider的BinderProxy。
-
如果该Provider已被调用进程使用过,则调用进程会保留使用过provider的HashMap。此时直接从此表查询即得。
②调用BinderProxy的query()
7.如何使用ContentProvider进行批量操作?
通常进行数据的批量操作我们都会使用“事务”,但是ContentProvider如何进行批量操作呢?创建 ContentProviderOperation 对象数组,然后使用 ContentResolver.applyBatch() 将其分派给内容提供程序。您需将内容提供