Binder面试总结

多进程的优势
  1. 突破进程内存限制
  2. 规避内存泄漏
  3. 隔离风险
【字节】binder有什么优势

在这里插入图片描述

【腾讯】binder如何做到一次拷贝

通过mmap,发送方的内核空间与接收方的用户空间有一块内存是共享的,接收方可以直接去拿;共享内存与binder用的都是mmap,共享内存是发送方与接收方同时映射到一块内存,容易死锁,binder则是把发送方的数据放到内核空间,如此是发送方的内核空间与接收方的用户空间实现共享

【阿里】binder机制是如何跨进程的

进程隔离所以不能直接通信,但是内核空间是共享的,所以发送方可以把数据发送到内核空间,通过copy_from_user把数据拷贝到内核空间,内核空间与接收方用户空间同时映射到同一块物理内存,所以数据相当于进入了接收方。映射是通过mmap实现的

【字节】aidl生成java类的细节
  1. 通过asInterface判断是否为同进程,返回代理对象
  2. data(发送的)、reply(回来的)包装数据;
  3. remote.transact 客户端挂起(同步),等待服务端回应 — 进入驱动
  4. 服务端通过方法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不能传递大数据
  1. Intent 无法传递大数据是因为其内部使用了 Binder 通信机制,Binder 事务缓冲区限制了传递数据的大小。
  2. Binder 事务缓冲区的大小限定在 1MB,但是这个尺寸是共享的,也就是并不是传递 1MB 以下的数据就绝对安全,要视当前的环境而定。

Binder这块实在太深了,以现在的理解还写不出完整的文章,下次一定!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值