跨网络通信
- Socket 本地通信,进程从zygote进程fork的指令都是用socket本地通信的
跨应用/进程通信
不考虑上面用跨网络通信方式来解决 跨应用/进程通信
- 文件 基于Linux的文件解决了并发读/写的问题。所以可以基于文件通信,避免并发写的问题
- IBinder
- Bundle/Intent Intent跨进程通信,Bundle携带数据ArrayMap 场景:四大组件传递消息
- AIDL 客户端: aidl接口动态生成IxxManager(远程代理类) 代理类实现接口方法 调用构造参数IBinder的transact()传输对应的方法参数阻塞调用 asBinder()得到这个代理类的实例供客户端使用 服务端: aidl接口动态生成IxxManager 创建IxxManager的stub匿名Binder实现接口方法的实际调用代理 将binder通过onBind返回 场景:高并发,远程方法调用
- Messager messager对Handler进行了封装 服务端Handler处理发送的消息 Messager通过OnBind()方法转成IBinder给客户端 客户端通过Messager.send()发送消息给服务端 服务端通过Handler.handleMessage处理message对象,可从msg.replyTo的获取客户端的Messager,向客户端发送消息 场景:低并发,互相传递消息
- Binder池 多个Binder(线程)在单个service上执行(一个service完成多个AIDL接口工作)
- ContentProvider 提供不同应用之间数据共享的方式,定义authorities为处理URI的路径。提供对本地数据库表的CRUD操作。
- Broadcast 全局广播监听,广播监听action动作处理主线程,发送action广播
跨进程传输对象序列化和反序列化
- Serializable 标记接口,无需实现,系统调用ObjectInputStream/ObjectOutStream等自动序列化和反序列化所有属性(除trainsient关键字标记属性外)
- Pracelable 需要实现类实现具体需要哪些序列化和反序列化的属性
跨组件/线程通信
不考虑上面用跨网络通信方式和跨应用/进程通信方式解决跨组件通信
跨组件通信
- Handler 单线程模型。(threadLocal+looper+handler) 耦合的主线程通信(发送者和处理者高度耦合)
- LocalBroadcastManager 发送的私有数据不同担心会被公开、没有第三方应用发送数据给你,不用担心别人利用你的漏洞、比全局广播传递数据更高效。 handler分发在主线程处理广播消息+根据Intent-filter的actions分发注册监听action的广播接手者 解耦的主线程通信(handler的高级扩展)
- RxBus 单线程通信(仅仅支持组件通信)
- Otto 解耦主线程通信(注解订阅)
- EventBus 当前线程消息队列串行消息+根据消息class找到订阅消息的处理者,然后分发线程调用处理对象处理 实现相当于LocalBroadcastMangaer升级版,注解和(反射/注解处理器)订阅,切换线程处理消息。 解耦的线程通信组件
组件内异步任务
- Thread+Handler 实现异步任务+主线程通信 场景:少量的短耗时任务
- AsyncTask 实现异步任务,可以支持更新UI和进度。(ExcutorService+Handler) 异步任务执行+主线程通信组件 场景:少量短耗时任务,如网络请求、数据库等
- LoaderManager 异步数据加载、数据源监听变化、横竖屏切换数据保留 contentProvider读取数据IO操作异步任务+主线程通信 场景:数据库读取短耗时任务
- RxJava 通信角度:异步任务+线程通信 场景:文件处理、数据库、网络请求短耗时任务
- IntentSerivce 处理异步任务的Service。(Looper+Thread+Handler) 脱离组件运行的异步任务 场景:单次下载任务这些长耗时任务
- Service+process 脱离组件运行的后台任务 场景:多次下载、多媒体后台播放、推送服务等长耗时任务