阿里P7Android高级架构进阶视频免费学习请点击:https://space.bilibili.com/474380680
本篇文章将先从以下三个内容来介绍通信方案:
- [Activity与Fragment之间的通信交互]
- [ Service和Activity的相互通信]
- [Intent传递数据大小限制]
一、Activity与Fragment之间的通信交互
1.1、APP构成
MainActivity+底部导航栏;
1.2、通信目的
MainActivity中成员方法test(),fragment中经test()方法判断后,方可执行下一步操作,如执行界面跳转;
例:
如上述示例代码,在fragment中需要对mBaiDuSDK_is_Ok进行值判断,执行界面跳转;
1.3、解决方法
二、Service和Activity的相互通信
2.1第一种方式:通过MyBinder方式调用Service方法
步骤
- 继承Binder 定义中间人对象
BanZhengService
- 重写ServiceConnection,onServiceConnected时调用中间人对象 绑定服务
MainActivity
2.2 第二种方式:通过接口Iservice调用Service方法
使用借口调用service和直接调用其实本质都是一样的,只不过多了借口一个步骤,
即实现步骤
- 1.继承Binder 定义中间人对象
- 2.定义接口
- 3.重写ServiceConnection,onServiceConnected时调用中间人对象,强转为接口(
myBinder = (Iservice) service;
) 绑定服务
这里就写一下不同的地方,其他都和上面的第一种一样
MainActivity
三、 Intent传递数据大小限制
3.1前言
在sendBroadcast,startActivity时,我们会用到Intent。
Intent可以携带一些数据,比如基本类型数据int、Boolean,或是String,或是序列化对象,Parcelable与Serializable。
Intent传递数据时,如果数据太大,可能会出现异常。比如App闪退,或是Intent发送不成功,logcat报错等等。
这就牵涉到一个问题:Intent 传递数据大小限制。
Intent到底能够携带多少数据呢?
使用Intent传送数据时,可能会出现异常
在Intent中传入一个Parcelable对象;例如传入一个bitmap对象。
选择bitmap的原因是,Bitmap实现了Parcelable接口,并且可以通过getByteCount()得知所占内存大小。
sendBroadcast时,报出如下信息:
查看异常类TransactionTooLargeException,它继承了RemoteException
追踪到Binder,它的transactNative方法会报出RemoteException
抛出异常与Binder有关。
Intent携带信息的大小受Binder限制
Intent携带信息的大小其实是受Binder限制。本文标题也可以改为“Binder传递数据大小限制”。
数据以Parcel对象的形式存放在Binder传递缓存中。
如果数据或返回值比传递buffer大,则此次传递调用失败并抛出TransactionTooLargeException异常。
Binder传递缓存有一个限定大小,通常是1Mb。但同一个进程中所有的传输共享缓存空间。
多个地方在进行传输时,即时它们各自传输的数据不超出大小限制,TransactionTooLargeException异常也可能会被抛出。
在使用Intent传递数据时,1Mb并不是安全上限。因为Binder中可能正在处理其它的传输工作。
不同的机型和系统版本,这个上限值也可能会不同。
在其它地方,例如onSaveInstanceState(@NonNull Bundle outState),也可能会遇到与Binder有关的类似问题。
为什么Binder要限制传输数据的大小
个人推测,作为一种IPC的方式,Binder并不是为传输大量数据而设计。
传输大量数据,可以考虑URL之类的方法。
阿里P7Android高级架构进阶视频免费学习请点击:https://space.bilibili.com/474380680
参考
https://www.jb51.net/article/159479.htm
https://www.jianshu.com/p/4b0cbe068555
https://www.jb51.net/article/120494.htm