iOS 静态库和动态库对ipa包大小的影响

        iOS中会经常使用到静态库和动态库,尤其稍大点的项目,有一些人对到底是推荐使用静态库还是动态库存在一些疑点。这里鼓励跟苹果爸爸走,尽可能的使用静态库, 下面会重点介绍静态库对包大小的影响。

静态库和动态库的区别这里不做过多的介绍,只贴下大家对他们的观点

对比一下静态和动态库的优缺点

静态库

优点:

1、直接链接到目标程序中,不需要动态链接,提高加载效率。 

缺点:

1、 会使用目标程序的体积增大。

动态库

优点:

1、 不需要拷贝到目标程序中,不会影响目标程序的体积。

 2.、同一份库可以被多个程序使用。

 3. 编译时才载入的特性,也可以让我们随时对库进行替换,而不需要重新编译代码。实现动态更新

缺点:

1. 动态载入会带来一部分性能损失 。


        这是很常见的认知,理论上也没有什么问题,但是这里对包大小的影响,角度上跟实际项目中却不一样。

比如SDWebImage打成动态库大小为648kb


而静态库大小为1.2M


        为啥说角度不一样呢,目前这个大小是站在单个库上面讨论的。 就单个而言静态库比动态库大多了。

而实际上我们是要使用一堆库并导出一个ipa的,我们要从对整体的影响上来看可能是另一个结果。

为啥是另一个结果呢,我们慢慢实验。

这里先说下本项目是在Xcode12模拟器下测试的,是单x86_64架构。

测试工程依赖的第三方库有AFNetworking、DoubleConversion、Folly、glog、libwebp、SDWebImage。

首先先看测试工程下各组件静态库下大小

SDWebImage:1.2M

AFNetworking:1.3M

DoubleConversion:406KB

folly:5.6M

glog:1.2M

libwebp:2.6M

这些静态库总大小都超过10M了,而最后出了多少货呢?

最后发现出的货在2M左右(不是App Store大小,仅做参考)


这里大家肯定都很理解,也没觉得奇怪在哪里。

是的,静态库最终链接到主可执行文件却变小了,这个大家肯定都是遇到过,知道估算包大小是无法使用静态库的大小来算的。

那么为啥变小了呢,猜测可能有几个原因

1、静态库里面含有一些符号信息便于定位,(为啥这样说,别人给你的库带有dSYM吗? 但是我们依然能定位到行数) 在链接完符号信息剥离出去,只留下真正可执行的二进制。

2、头文件等一些文件没了,可以忽略不计

3、静态库中的是中间文件,链接过程优化了静态库里面的.o文件

下面是使用hopper打开静态库的提示,跟已经编译好的动态库完全不一样。


那么静态库链接后对包大小没有显示的大小那么大,为啥会有人拿单个库做比较呢。

如果还不相信,那么我们来看看动态库对最终的包大小有哪些影响。

同样的项目,把依赖的第三方库全部改成动态库。

大小如下:

SDWebImage:648KB

AFNetworking:797KB

DoubleConversion:262KB

folly:2M

glog:510KB

libwebp:1.2M

从这些数据来看,确实每一个都小很多,但是大家忽略了一点,静态库参与链接到主可执行文件会变小很多,而动态库却不会,它是以什么形式存在呢。

打开app内部,查看里面的目录,大家可以看到熟悉的Frameworks目录


这个目录里面都是存放一些动态库,动态库是copy进去的,当然会做一些签名、去除头文件等操作,编译器几乎不会对动态库做过多的事,所以一些朋友可能会遇到打包的时候App Store提示不能包括i386,x86_64等模拟器的架构,因为它对动态库没做剔除工作。

那么这些copy过去的库大小有什么变化,答案是几乎没什么变化,可能因为去除一些没用的东西小了一丢丢。

Frameworks目录总大小也在4.9M,和上面的数据差不多。

而打出的包在5M左右。

所以可以看到最终动态库打出的ipa是大于静态库的。

使用hopper打开动态库我们可以看到AFNetworking和SDWebImage的动态库里面有关一些基础的使用方法存在重复Name,却不同的Address,比如这个dispatch_once。


那么我们可以猜出每个动态库里面会有一些其他的调用信息,而因为动态库是独立的,具有隔离型,相互不影响。

静态库大却在最终的链接优化掉,而动态库却完完全全copy过去,那存在一些重复的信息怎么办?

这个最终也是造成包变大的一个因素,当然也可能存在其他原因。


而动态库还存在动态链接影响性能的问题(当然有些人会延迟链接也是一种办法)

动态库也不能真正的共享,

动态库依赖静态库这种关系复杂起来也难倒了好一些人。

所以我们一直鼓励尽可能的使用静态库。 当然也不是说动态库不使用,有时候解决一些依赖问题,也会用的到,但是尽量少用,我们项目因为全部改成静态库整整小了20M左右。

所以结论是:静态库单个虽大,但是链接到主可执行文件中就会小很多,并且加快了启动时间。

以上均测试出来的数据,如果问题请指出, 本文结论仅供参考。

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