亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android中關于Binder常見面試題有哪些

發布時間:2022-06-30 10:01:22 來源:億速云 閱讀:211 作者:iii 欄目:開發技術

本篇內容主要講解“Android中關于Binder常見面試題有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Android中關于Binder常見面試題有哪些”吧!

1.簡單介紹下binder

binder是一種進程間通訊的機制

進程間通訊需要了解用戶空間內核空間

每個進程擁有自己的獨立虛擬機,系統為他們分配的地址空間都是互相隔離的。 如兩個進程需要進行通訊,則需要使用到內核空間做載體,內核空間是所有進程共享的一塊內存區域。 而用戶空間切到內核空間需要使用到系統api ioctl進行通訊。內核獲取用戶的數據需要使用copy_from_user,內核將數據發送給其他進程需要使用copy_to_user,這兩個方法是有性能開銷的,對于socket就是使用的這種模式,為了減少這部分的開銷,內核提供了binderbinder只需要一次拷貝就可以實現進程通訊.

主要是使用mmap的原理:

內核空間用戶空間都開辟一塊虛擬內存區域同時指向一塊物理地址,這樣內核需要傳遞數據給用戶空間時,只需要將數據拷貝到對應的虛擬內存地址中,用戶可以通過虛擬內存映射關系,獲取到內核中的數據,實現了一次拷貝通訊。

binder架構上面使用的是C/S架構:

Android中關于Binder常見面試題有哪些

binder中有三要素:
客戶端,服務端和ServiceManager

binder整體過程:

1.注冊服務 2.獲取服務 3.使用服務

Android中關于Binder常見面試題有哪些

2.Binder的定向制導,如何找到目標Binder,喚起進程或者線程?

數據結構流程:

1.server注冊過程 
      1.server傳入一個flat_binder_object給內核態。內核根據這個flat_binder_object創建binder_node節點,為每個進程服務,內部有個binder_proc.proc = server進程
      2.serviceManager在內核態創建binder_ref引用這個binder_node,內部有一項desc = 1,2,3..,在用戶態會創建一個服務鏈表{name ="server name",handle = "server handle"}
2.client獲取服務過程
      3.client向sm查詢服務,傳遞name
      4.sm返回handle給驅動程序
      5.驅動程序在sm的binder_ref_desc紅黑樹中根據handle找到binder_ref,再根據binder_ref.node找到binder_node,最后給client創建新的binder_ref指向這個binder_node,他的desc從1開始binder_ref{desc=1,node = binder_node},驅動返回desc給client,即handle總結:sm中的handle順序是根據服務注冊順序顯示,返回給client中的handle是根據服務獲取的順序顯示的
3.client使用handle過程
      6.:驅動里面根據handle找到找到binder_ref,根據binder_ref找到binder_node,根據binder_node找到進程server

注:

flat_binder_object{
    type:是binder實體還是引用,只有需要注冊的服務可以傳binder實體,其他只能傳handle引用
    flag(聯合體)
    binder(實體:處理函數)/handle(引用:服務的引用):
    cookie
}

數據傳輸過程(進程切換):

Android中關于Binder常見面試題有哪些

數據如何復制:

Android中關于Binder常見面試題有哪些

3.Binder中的紅黑樹,為什么會有兩棵binder_ref紅黑樹

  • refs_by_desc主要是通過desc來查找對應的binder_ref

  • refs_by_node主要是通過node來查找對應的binder_ref

查找方式不一樣

4.Binder一次拷貝原理

傳統的數據拷貝方式如socket

用戶空間---->內核空間:`copy_from_user `
內核空間---->用戶空間:`copy_to_user`

而binder使用mmap機制

在內核空間和用戶空間中間使用物理地址開辟了一個映射關系
內核空間調用copy_from_user會直接將數據拷貝到內核空間并反饋到映射后的物理地址上,
由于用戶空間和物理地址也有個映射關系,用戶空間可以直接通過映射的虛擬地址指針訪問到寫入物理地址的數據。
這就是binder一次拷貝的原理

5.Binder傳輸數據的大小限制?

對于內核可以傳輸的是4M,但是應用層限制在1M-8K范圍內,這就是在進程間傳輸過大的數據會導致崩潰的原因

6.系統服務與bindService等啟動的服務的區別

系統服務需要將服務注冊到ServiceManager,使用的時候需要通過服務名稱去ServiceManger中獲取服務的引用,

bindService等啟動的服務是將服務注冊到AMS中的ServiceMap中,所有的服務的生命周期都由AMS控制。啟動服務的進程如果需要使用IPC通訊,都是和獲取AMS的代理類進行通訊,AMS也是在SystemServer啟動的時候一個注冊到ServiceManager的系統服務。

7.Binder多線程

binder線程池默認提供了15個線程進行處理進程間并發事件,如果服務端線程不夠用,則驅動會發出一個信號,應用層收到這個信號調用Register_Thread,這樣驅動層就可以使用這個新建出來的子線程進行數據的處理

8.Android APP進程天生支持Binder通信的原理是什么?

Android APP進程都是由Zygote進程孵化出來的。

常見場景

點擊桌面icon啟動APP,或者startActivity啟動一個新進程里面的Activity,最終都會由AMS去調用Process.start()方法去向Zygote進程發送請求,讓Zygotefork一個新進程,Zygote收到請求后會調用Zygote.forkAndSpecialize()fork出新進程,之后會通過RuntimeInit.nativeZygoteInit來初始化Andriod APP運行需要的一些環境,而binder線程就是在這個時候新建啟動的

virtual void onZygoteInit()
{
    sp proc = ProcessState::self();
    //啟動新binder線程loop
    proc->startThreadPool();
}

9.同一個線程的請求必定是順序執行,即使是異步請求(oneway)

一般而言,Client同步阻塞請求Service,直到Service提供完服務后才返回,不過,也有特殊的,比如請求用ONE_WAY方式,這種場景一般主要是用來通知,至于通知被誰消費,是否被消費壓根不會關心。 拿ContentService服務為例子,它是一個全局的通知中心,負責轉發通知,而且,一般是群發,由于在轉發的時候,ContentService被看做Client,如果這個時候采用普通的同步阻塞勢必會造成通知的延時發送送,所以這里的Client采用了oneway,異步。

到此,相信大家對“Android中關于Binder常見面試題有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

吉林省| 沙雅县| 错那县| 招远市| 开阳县| 肥乡县| 张家港市| 铜鼓县| 辽宁省| 五常市| 乌拉特后旗| 江阴市| 滨海县| 祁连县| 宁阳县| 台南县| 广州市| 山西省| 武陟县| 江达县| 浑源县| 获嘉县| 临湘市| 思茅市| 延川县| 石嘴山市| 右玉县| 鸡东县| 栾城县| 锡林浩特市| 宜黄县| 遂昌县| 夏津县| 敦化市| 郧西县| 尤溪县| 扬中市| 杭锦旗| 麻江县| 石嘴山市| 万盛区|