iOS 問答02-iOS 系統框架及進程間通信

問題

開始正文前:先拋出幾個問題,帶著疑問閱讀下面的文章,應該會更有收獲。

  1. iOS 系統架構可以分為幾層?
  2. Darwin 層又可以分為幾部分?能否簡單介紹下各部分?
  3. IPC 是什么?,有哪些常見 IPC?iOS 中一般采用什么方式進行 IPC?能否舉一些 IPC 的例子出來?
  4. 能否介紹一下宏內核、微內核、混合內核以及各自的優劣?

1 iOS 系統架構

上一次問答在說到 iOS 事件響應流程時,提到了 iOS 系統框架中的 IOKit 和 SpringBoard。今天就深入展開介紹一下 iOS 的系統框架。

iOS 系統可以分為四層,從下往上介紹:

  1. 第一層是 Darwin 層,是操作系統的核心,屬于操作系統的內核態,包括了系統內核 XNU,驅動等,是開源的,可在 opensource.apple.com 找到。
  2. 第二層是核心框架層,包括 Metal、OpenGL 等。
  3. 第三層是應用框架層,比如 Cocoa Touch 框架。
  4. 第四層是用戶體驗層,包括用戶能接觸到的圖形應用,如 SpringBoard(桌面系統,統一管理和分發系統接收到的觸摸事件)、Spotlight。
iOS 系統架構-摘自戴銘博客

上面提到 Darwin 層屬于操作系統的內核態,而其余的三層,核心框架層、應用框架層、用戶體驗層屬于用戶態。

Darwin 的內核是 XNU,全稱 'XNU’s Not UNIX'。下面會著重介紹一下 XNU。如上圖所示,XNU 主要由以下三項組成:

  1. Mach
  2. BSD
  3. IOKit
Darwin 層架構

2 Mach

2-1 Mach 基本介紹

Mach 是 XNU 內核的內環,屬于微內核,只提供了處理器調度、進程間通信(IPC)、內存保護、虛擬內存管理、進程和線程的抽象等功能。

2-2 IPC

Mach 的核心功能是 IPC(Inter-Process Communication)。在 Mach 中,所有東西都是屬于對象范疇的,比如進程、線程、虛擬內存。對象間是不能直接相互調用的,必須通過消息傳遞的方式實現,消息會在兩個端口之間傳遞,也就是基于 mach port。當處于用戶態的核心框架層、應用框架層、用戶體驗層需要進行系統調用的時候,會調用 mach_msg_trap() 觸發陷阱機制,切換到內核態,內核態中實現 mach_msg() 函數完成最后的工作。具體過程如下:

摘自YY大神博客

RunLoop 的核心就用到了 mach_msg(),當沒有接收到 port 消息時,內核會將線程置為等待狀態,節省資源。

在 iOS 屏幕渲染過程,同樣會利用到 IPC。

在 Xcode 中運行 App 時,點擊調試欄中的暫停按鈕,也可以看到主線程調用棧停留在 mach_msg_trap()

4.png

在 iOS 中,剪貼板(Pasteboard)同樣屬于進程間通信方式的范疇。

(IPC 參考鏈接)[https://nshipster.com/inter-process-communication/]

3 BSD

Mach 本身提供的 API 有限,額外功能需要 BSD 來實現,BSD 可以看做圍繞 Mach 層的一個外環,提供了更高層次的抽象,提供了進程管理、文件系統、網絡諸多功能。屬于宏內核。

4 IOKit

IOKit 是硬件驅動程序的運行環境,包括電源、內存、CPU 等信息。為設備驅動提供了一個面向對象(C++)的框架。

這里再簡單講一下 Darwin 層 IOKit、用戶體驗層中的 SpringBoard 在觸摸事件中起到的作用:

  1. 用戶觸摸屏幕,屏幕硬件將事件通過 mach port 發送給 IOKit
  2. IOKit 將觸摸事件封裝成 IOHIDEvent 對象,通過 mach port (進程端口通信)傳遞給 用戶體驗層的 SpringBoard
  3. SpringBoard 會判斷,如果在桌面,則交由系統進程去消耗
  4. 如果是在應用中發生,將觸摸事件通過 IPC 傳遞給對應應用(source1),source1 喚醒 RunLoop,將事件分發給 source0,_UIApplicationHandleEventQueue 將 IOHIDEvent 包裝成 UIEvent 向下分發

5 Mach、BSD 和微內核、宏內核、混合內核

前面的內容提到 Mach 屬于微內核,BSD 屬于宏內核,那這樣安排的用意是什么呢?這里簡單解釋一下。

在微內核中,用戶服務和內核服務是在不同的地址空間實現的。因此在用戶態如果要進行系統調用的話,需要通過消息傳遞的方式進行通信,隨之帶來的缺點是消息傳遞會造成執行速度變慢。

優點:

  1. 健壯性:用戶服務和內核服務是相互獨立的,用戶服務的崩潰不會影響到內核服務。
  2. 擴展性強:添加新的功能,只需要建立一個新的服務到用戶空間即可,內核空間不需要做出修改。
  3. 占用內存小:內核是常駐內存當中,因為內核服務只有一些最基本的功能,所占內存空間小。

而在宏內核中,用戶服務和內核是在同一空間中實現的。因此不需要經過消息傳遞,執行速度比微服務快。但是微內核所擁有的優點,則變成了宏內核的劣勢。

既然微內核和宏內核,各自有優點,那何不把兩個結合一下,各取所長呢。這就是混合內核了。大致做法是,混合內核會把一些不經常使用的內核模塊從內核中移出,從而降低了內核的復雜程度。

XNU 采用的就是微內核 Mach 和宏內核 BSD 的混合內核。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,333評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,491評論 3 416
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,263評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,946評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,708評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,409評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,939評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,774評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,976評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,209評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,641評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,872評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,650評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,958評論 2 373