Cocoapods工程编译优化

2019-08-27  本文已影响0人  缓步节兮安歌

网上方案

Carthage

放弃原因:
 存在多个pod时,执行命令存在引起其它对象下载或编译的现象存在。
 静态化库需要修改工程scheme为share,并修改mach-type为static

use-frameworks!

放弃原因:
 pod工程依赖,clean命令时,会关联清除。
 framework会使ipa大很多

cocoapod-package

原理:
 提前生成pod的vendor_framework,目标工程直接引用vendor
操作:
 需要先下载目标pod git, 切换至指定tag
 使用pod package命令进行操作,导出framework
 处理生成的pod-version文件夹
 将Podfile中pod的引用指向pod-version/*.podspec
放弃原因:
 导出的podspec经常性的缺失public header, 需要修改源podspec

CCache

原理:
 ccache底层对编译文件进行缓存,阻止二次编译
放弃原因:
 不支持module, 而swift必须要求开启module

Cocoapod-binary

放弃原因:
原理:
通过Pods生成Prebuild文件夹,将Pod工程指向Prebuild/Pod.xcproj
Prebuild工程提前对相关pod进行编译
放弃原因:
 工具不完善, 会出现workspace未创建,引入的framework找不到等各种问题。

最终方案

截取pod输出文件,直接导入工程

步骤

效果

一次性导出41个pod, 节省全量编译时间400s

注意事项

WCDB必须用动态库导出,其与FMDB有冲突,不支持静态库,会引起sqlite多份代码。
若其它Pod中引用了预编译中也包括的库,可能会存在多份代码,建议动态库支持。

上一篇 下一篇

猜你喜欢

热点阅读