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阅读 220,458评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,030评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,879评论 0 358
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,278评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,296评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,019评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,633评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,541评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,068评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,181评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,318评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,991评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,670评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,183评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,302评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,655评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,327评论 2 358