用最通俗的语言总结Android Binder

角色: client 、 service 、 serviceManager 、Binder驱动

场景: 前三出演在用户空间,后者在内核空间作为幕后

剧本: a. client带着“绝密级文件”需要跟神秘的service进行会晤

b. client只知道service名字,但不知其人

c. service压根就不知道有client会找她

后台策划1: 如下图


剧场开幕: 基于以上剧本开演,

a. 由于业务发展client需要开展(调用)某项技能xx(方法)

b. 而这项技能掌握在server这种明星的手上

c. 由client(这种平民)直接要接触到server,显得太为不可能,那怎么拿到该项技能呢?

d. 代理,中间代理(就像租房中介)ta负责转接“上与下(地位悬殊)”以及“租客与房东”此类关系的各种需求

e. proxy这里指的虚拟代理,真实代理还是binder负责

f.  binder 在kernel 空间里为每一个进程开辟了一块用来做“黑交易(数据交互)”的内存区(存放client 与 server 进程处理的数据)

智能的binder 为了提高“交易效率与数量”实现了一套机制,不仅为每个进程创建一块内存区,

此外 还“专门开辟了一块共享内存区用来存放处理完数据(以用来减少从kernel复制数据到用户空间)” 见下面粉色(粉色粉色的)的图

g. binder 对client来说, 将请求打包成binder特有格式“paracel”传输到 server

binder 对server来说,将client给到的请求进行处理后,把结果包装到paracel 送到binder 进行发货

i.  client 可以选择两种方式来等待server处理结果: 阻塞(同步)一直专心致的等啊等,非阻塞(异步)提出了要求后,就不管了(跑了去干啥啥了)

h. 以上是每一次client  通过 binder call method细节。

其实可总结为(“换做一种好理解的方式”),client通过binder 成功地获取server对象实例的代理后,在本地任何操作就像是server亲自发出指令一样。

(这也是所谓的代理模式.... 姑且这么不恰当理解&诠释),不服的(不服的来打架啊.....)


后台策划2:


剧场开演戏2: 基于策划2开演

导演不满意,还要继续BB.....

a. 例如client想要做一个“人生保健服务”但又不知道去哪里找店,于是打开手机输入字段“人生保健服务”,过了几秒手机端就显示了“周围”(系统所具备的服务)

b. 这里的ServicesManager将查询结果(指向服务对象的类指针)返回给Client,

c.  Client 拿到“地址”踹紧口袋立马打了一个滴滴屁颠颠的去店里做保健(向服务端call method,以期等待得到特定数据)

d.  Client怎么找到服务的呢? 原因是server早已在ServiceManager里面注册自己的门店,以等待顾客上门消费

e.  上面的一切都是在Binder地盘上完成交易,无奈他是老大,提供了交易平台(否则,你以为随随便便就能找到保健店吗,天真 ......)

剧终谢幕,采访幕后者“Binder”

在以上交易完成后,请问

a.  如何做到做好对接client 与server 的数据交互(通信传输)?

b.  在系统里面面对多个client 有请求数据时,如何做到一一不落响应每个客户的请求?

c.  binder挂掉了怎么办?

以下统一回复:  谢谢 。

BpBinder对象:

a.  客户端通过它(IBinder)将数据请求传达到Server端

BpBinder::transact(code ,Paracel&data,Paracel*reply, flags )

b. 紧接着IPCThreadState::transact(handle , code , Parcel &data , Paracel *reply , flags )收到命令立即将数据

装入mOut变量里 (viawriteTransactionData(BC_TRANSACTION,flags , handle , code , data , NULL)

c.  再通过waitForResponse(reply)  把mOut的数据通过ioctl发送给 binder驱动  , 并得到 驱动返回处理数据.   // 这里可设置等待方式(TF_ONE_WAY同步)

d. binder 只有一个文件描述符,  系统里多客户进程同时执行远程调用,并在ioctl上等待 处理结果, Android 如何保证其处理返回的数据能正确的交到正确的进程呢?

这就是核心: "Android 在binder驱动里记录每次binder调用信息(包含线程ID),这样根据ID可以知道将对应的数据交给那个等待线程,唤醒该进程来读取缓冲区数据"

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容