接下来通过一个实例来看看怎么具体地借助 ContentProvider 和 Binder 来进行便捷的跨进程通信。
Server进程
服务端接口定义
在服务端进程或者服务端 App 中,定义 AIDL 接口文件:
interface IMyAidlInterface {
int getCount();
}
make 之后实现接口:
class CountServiceImpl : IMyAidlInterface.Stub() {
override fun getCount(): Int {
println(“Server: getCount”)
return 100
}
}
ContentProvider定义
接着注册并定义一个运行在服务端进程的 ContentProvider 对象:
class BinderProvider : ContentProvider() {
override fun onCreate(): Boolean = true
override fun query(
uri: Uri, projection: Array?, selection: String?, selectionArgs: Array?, sortOrder: String?
): Cursor {
return BinderCursor.binderCursor
}
override fun getType(uri: Uri): String? = null
override fun insert(uri: Uri, values: ContentValues?): Uri? = null
override fun delete(uri: Uri, selection: String?, selectionArgs: Array?): Int = 0
override fun update(uri: Uri, values: ContentValues?, selection: String?, selectionArgs: Array?): Int = 0
}
这里 query 方法中返回的 Cursor 对象是一个 BinderCursor.binderCursor, BinderCursor 继承自 MatrixCursor 类,其内保存有服务端 Binder 对象:
class BinderCursor private constructor() : MatrixCursor(arrayOf(“service”)) {
companion object {
private const val KEY_BINDER_COUNT = “key_binder_count”
val binderCursor = BinderCursor()
fun getCountService(cursor: Cursor?): IBinder? {
return cursor?.extras?.getBinder(KEY_BINDER_COUNT)
}
}
private val mBinderExtra = Bundle()
init {
mBinderExtra.putBinder(KEY_BINDER_COUNT, CountServiceImpl())
}
override fun getExtras(): Bundle {
return mBinderExtra
}
}
然后在 Manifest 中注册:
小福利:
在当下这个碎片化信息环境的时代,很多资源都可以在网络上找到,只取决于你愿不愿意找或是找的方法对不对了
很多朋友不是没有资料,大多都是有几十上百个G,但是杂乱无章,不知道怎么看从哪看起,甚至是看后就忘
如果大家觉得自己在网上找的资料非常杂乱、不成体系的话,我也分享一套给大家,比较系统,我平常自己也会经常研读。
2021大厂最新Android面试真题解析
各个模块学习视频:如数据结构与算法
只有系统,有方向的学习,才能在段时间内迅速提高自己的技术。
这份体系学习笔记,适应人群:**第一,**学习知识比较碎片化,没有合理的学习路线与进阶方向。**第二,**开发几年,不知道如何进阶更进一步,比较迷茫。第三,到了合适的年纪,后续不知道该如何发展,转型管理,还是加强技术研究。如果你有需要,我这里恰好有为什么,不来领取!说不定能改变你现在的状态呢!点赞+评论即可获得!
或直接点击这里前往我的GitHub中下载,就可以白嫖啦,记得给文章点个赞哦。
%EF%BC%9F%E5%A6%82%E4%BD%95%E9%9D%A2%E8%AF%95%E6%8B%BF%E9%AB%98%E8%96%AA%EF%BC%81.md)中下载**,就可以白嫖啦,记得给文章点个赞哦。