xcode15-mergeable libraries

动态链接库(dynamic frameworks)

一般在动态链接库中的symbols并不会被包含到app的二进制文件中,一般是在app bundle的frameworks 文件下,会在app launch的时候加载这个动态链接库,这会花费app的启动时间

静态链接库(static libraries)

会在编译期间被链接到app的二进制文件中,但是这会增加build time

mergeable libraries

为了解决这个困境(静态库会增加开发者编译时间,动态库会增加使用者的启动时间),就让这些库在开发期间(debug mode)为动态链接库,在发布期间为静态链接库

新的链接器相较于之前有什么区别

原先的链接器

静态链接器主要是将多个目标文件(.o)作为输入,每个目标文件包含了已编译的代码和数据以及元数据(符号表)

然后链接器会对symbol进行解析,识别每个目标文件中定义的symbol(函数和变量名)然后将这些构建成一个符号表,

重定义:链接去解析每个目标文件中的symbol引用,然后通过符号表指引正确定义和分配相关内存

最终结果就是将这些静态链接库的所有数据会被包含到app的二进制文件中,这些静态连接库就没用了。

新的链接器

构建动态库是添加元数据,将动态库与静态库类似对待,合并后的输出文件可以是可执行文件或者另一个动态库,合并类似于静态库的链接方式,最终生成一个包含库的

先使用-make_mergeable选项告诉链接器记录元数据,然后为了merged binary,链接器使用元数据和二进制文件一起生成最终输出(通过-merge_library or -merge_framework选项),最终这个二进制文件将是一个包含segments的libraried,xcode还会对这个最终的二进制文件进行相关处理(When merging, the linker can de-duplicate content, such as strings, across all libraries. For instance, it removes redundant symbol references, Objective-C selectors, and objc_msgsend stubs.)

如何处理动态链接库为mergeable libraries:

当静态链接器创建二进制文件时,动态链接库也生成相应的元数据,这些元数据也是二进制的,允许静态链接器像对待静态连接库一样对待这些元数据的二进制数据(简单来说这些具有元数据的动态库会被静态链接器当作静态库处理),这些元数据的二进制数据可以被静态链接为一个动态链接库或者合并他们(merged binary),这个合并的方式和静态连接库链接的方式一致,

如何处理静态连接库

这个可能是以前的逻辑:?code不再从静态连接库copy进可执行程序,而是静态连接器记录静态库的安装路径在app二进制文件,关键的不同点在于当动态链接库被添加或更新时没静态链接器不再需要copy代码,这就回加快build的事件,但这也会倒置app在运行时变复杂,

操作

如何查看当前文件是动态还是静态

file xxx.a

如果出现current ar archive就是静态

如果输出包含 "shared object" 或 "dynamically linked",则表示这是一个动态链接库

如何删除多余的

-wl.-no_exported_symbols

链接器

ld64应该是老的静态链接器,dyld是动态链接器

相关推荐
jerrywus8 小时前
别再陪 AI 调 iOS 了:用 cmux + baguette,让 Claude 在你的模拟器里"自己动手"
前端·ios·claude
MonkeyKing71558 小时前
iOS 开发 Block 底层结构、循环引用及解决方案
ios·面试
文件夹__iOS8 小时前
Swift 5.9 被严重低估的特性:参数包,一次性干掉重复泛型重载
ios·swiftui·swift
薛定猫AI9 小时前
【技术干货】用 AI + Expo 打通 iOS / Android / Web 跨端应用开发:从架构到代码生成实战
android·人工智能·ios
MonkeyKing10 小时前
iOS关联对象底层实现与内存管理细节
ios
90后的晨仔1 天前
SwiftUI 高级特性第2章:组合与容器
ios
pop_xiaoli1 天前
【iOS】SDWebImage源码
macos·ios·objective-c·cocoa
MonkeyKing2 天前
消息发送与转发流程
ios
移动端小伙伴2 天前
我受够了 Xcode 的 SPM 网络问题,写了个脚本一劳永逸
ios
人月神话-Lee2 天前
两个改动,让这个iOS OCR SDK识别成功率翻了一倍
ios·ocr·ai编程·身份证识别·银行卡识别