多进程的优势
- 突破进程内存限制
- 规避内存泄漏
- 隔离风险
【字节】binder有什么优势
【腾讯】binder如何做到一次拷贝
通过mmap,发送方的内核空间与接收方的用户空间有一块内存是共享的,接收方可以直接去拿;共享内存与binder用的都是mmap,共享内存是发送方与接收方同时映射到一块内存,容易死锁,binder则是把发送方的数据放到内核空间,如此是发送方的内核空间与接收方的用户空间实现共享
【阿里】binder机制是如何跨进程的
进程隔离所以不能直接通信,但是内核空间是共享的,所以发送方可以把数据发送到内核空间,通过copy_from_user把数据拷贝到内核空间,内核空间与接收方用户空间同时映射到同一块物理内存,所以数据相当于进入了接收方。映射是通过mmap实现的
【字节】aidl生成java类的细节
- 通过asInterface判断是否为同进程,返回代理对象
- data(发送的)、reply(回来的)包装数据;
- remote.transact 客户端挂起(同步),等待服务端回应 — 进入驱动
- 服务端通过方法id找到执行代码,打包数据
【字节】四大组件底层的通信机制,以 bindService 为例
1.客户端进程与SM通信获得AMS的IBinder(第1次跨进程)
2.客户端通过AMS的IBinder与AMS通信,请求bindService(第2次跨进程)
3.AMS与服务进程通信执行Service的onBind(第3次跨进程)
4.服务端进程与SM通信获得AMS的IBinder
5.服务端进程通过与AMS的IBinder与AMS通信,发布自己的IBinder给AMS
6.AMS与客户端通信,转发服务端的IBinder(代理BinderProxy)
总共跨进程6次
【阿里】为什么intent不能传递大数据
- Intent 无法传递大数据是因为其内部使用了 Binder 通信机制,Binder 事务缓冲区限制了传递数据的大小。
- Binder 事务缓冲区的大小限定在 1MB,但是这个尺寸是共享的,也就是并不是传递 1MB 以下的数据就绝对安全,要视当前的环境而定。
Binder这块实在太深了,以现在的理解还写不出完整的文章,下次一定!