第二章IPC机制(Android开发艺术探索)

2024-09-03 02:08

本文主要是介绍第二章IPC机制(Android开发艺术探索),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.Bundle传递数据实现IPC(当然传递的类型必须要bundle支持)

特殊情况:传递的数据类型Bundle不支持的情况(即无法通过intent传输),
这种情况可以考虑:我们通过A进程中的Intent启动B进程的Service(比如intentService)来进行执行,执行完后再启动B进程中的目标组件

2.使用文件共享实现IPC(要注意并发读写的问题)
在windows上面,一个文件加了排斥锁,其他线程就无法访问
但是:android 是基于linux,并发读写文件无限制
附:反序列和序列化的内容是一样的,但是是2个对象


SharedPreferences在内存中有一份文件缓存
所以在多进程模式下,系统对它的读写就变的不可靠,面对高并发的读写访问,它有很大几率丢失数据,
所以不建议在进程间通信中使用SharedPreferences

3.使用Messenger实现IPC(信使,)
Messenger是串行的方式处理客户端的消息,如果有大量的并发请求就不太合适了,
messenger的作用主要是传递消息,并不能实现跨进程方法的调用
Messenger是对aidl进行了封装,只能发消息使用

4. 使用AIDL实现IPC
有一点要注意:客户端在onDestroy方法中解除注册到服务端的listener的时候,会出现can not unregister的情况,
原因是:对象是不能跨进程传输的,跨进程传输本质就是反序列化的过程,
这也是为什么AIDL的自定义对象都必须实现Parcelable接口的原因。
可以使用RemoteCallbackList:是系统专门提供的用于删除跨进程listener的接口(key,value的形式保存listener)

注意:
1.客户端调用远程服务的时候,如果远程方法比较耗时,那么客户端会出现ANR
解决:
避免在客户端的UI主线程中访问远程方法
2.同理,远程服务端调用客户端的耗时方法时,服务端也不要再UI线程中调用
3.如果服务端意外停止了(服务端的Binder可能意外死亡),那么客户端需要重新连接服务
方法1:服务端的Binder死亡,会收到binderDied方法的回调,我们在这个方法中重连
方法2:在onServiceDisconnected重连
两种方法的区别:
onServiceDisconnected在主线程,可以直接回调后进行ui操作
binderDied在客户端的binder线程池中回调,不能直接访问ui


AIDL权限验证:
默认情况下,远程服务任何人都可以连接
方法1:在onBind中验证,比如使用permission方式,在menifest中注册
方法2:在服务端的onTransact方法中验证

5.使用ContentProvider实现IPC
是android间专门用于不同应用间进行数据共享的方式,和messenger一样,底层是binder

6.使用socket实现IPC
socket的理解:
快递员:socket

数据发送过程:
1.产生socket
2.调用bind将socket的信息通知给驱动程序
3.应用程序把数据传给socket
4.驱动程序从socket中取出数据并通知网卡发送出去
接受数据过程:
1.产生socket
2.调用bind将socket的信息通知给驱动程序
3.驱动程序根据从网卡传送过来的数据报中”指定的目标端口号“,将处理的数据传送到相应的socket中,应用程序从socket中取数据


Binder连接池
AIDL:最常见的进程间通信方式
AIDL使用:
1.创建service接口,AIDL接口
2.创建一个类,继承AIDL接口中的Stub类,并实现抽象方法
3.在Service的onBind方法中返回这个类的对象
4.客户端绑定服务端的service,建立连接后就可以访问服务端的方法了
但是如果公司项目庞大,可能创建很多个service
解决方法:binderPool机制
1.一个业务一个AIDL
2.向服务端提供唯一标识和binder对象;服务端只需要一个service就好
3.服务端提供一个queryBinder接口,此接口返回相应的binder对象
binder连接池的作用:把每个业务模块的binder请求统一转发到远程service,这样避免重复创建service

选择合适的IPC方式
1.Bundle:优点:简单易用  缺点:只能传输Bundle支持的数据类型 使用场景:四大组件间的进程通信
2.文件共享优点:简单易用 缺点:不适合高并发的情况,并且无法做到进程间的即时通讯 使用场景:无并发访问情况下,交换简单的数据实时性不高的情况
3.AIDL:优点:功能强大,支持一对多并发通信,支持实时通讯  缺点:需要处理好线程同步 使用场景:一对多通信且有Rpc需求
4.Messager:优点:支持一对多串行通信,支持实时通讯 缺点:不能很好处理高并发情况,不支持Rpc,数据通过Message进行传输,因此只能传输Bundle支持的数据类型 使用场景:低并发的一对多即时通信,无Rpc需求,或者无需返回结果的Rpc需求
5.ContentProvider :优点:在数据源访问方面功能强大,支持一对多并发数据共享,可通过call方法扩展其他操作(call在源码编译下可调用http://blog.csdn.net/luoshengyang/article/details/6950440) 缺点:主要提供数据源的Crud 使用场景:一对多的进程间数据共享
6.Socket: 优点:功能强大,可以通过网络传输字节流,支持一对多并发实时通讯 缺点:实现细节有点繁琐,不支持直接的Rpc
来源: <http://blog.csdn.net/q178266871/article/details/50394486>


















这篇关于第二章IPC机制(Android开发艺术探索)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1131717

相关文章

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

Android协程高级用法大全

《Android协程高级用法大全》这篇文章给大家介绍Android协程高级用法大全,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友跟随小编一起学习吧... 目录1️⃣ 协程作用域(CoroutineScope)与生命周期绑定Activity/Fragment 中手

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

基于Redis自动过期的流处理暂停机制

《基于Redis自动过期的流处理暂停机制》基于Redis自动过期的流处理暂停机制是一种高效、可靠且易于实现的解决方案,防止延时过大的数据影响实时处理自动恢复处理,以避免积压的数据影响实时性,下面就来详... 目录核心思路代码实现1. 初始化Redis连接和键前缀2. 接收数据时检查暂停状态3. 检测到延时过

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

Python开发简易网络服务器的示例详解(新手入门)

《Python开发简易网络服务器的示例详解(新手入门)》网络服务器是互联网基础设施的核心组件,它本质上是一个持续运行的程序,负责监听特定端口,本文将使用Python开发一个简单的网络服务器,感兴趣的小... 目录网络服务器基础概念python内置服务器模块1. HTTP服务器模块2. Socket服务器模块

Android 缓存日志Logcat导出与分析最佳实践

《Android缓存日志Logcat导出与分析最佳实践》本文全面介绍AndroidLogcat缓存日志的导出与分析方法,涵盖按进程、缓冲区类型及日志级别过滤,自动化工具使用,常见问题解决方案和最佳实... 目录android 缓存日志(Logcat)导出与分析全攻略为什么要导出缓存日志?按需过滤导出1. 按