一、前言
这篇主要是记录一下 iOS 下静态库与动态库的打包流程,以便以后用到时快速查阅,供自己也供大家学习记录。同时也简述了一下动态库与静态库的区别。
二、静态库与动态库
1、库
库是写好的现有的,成熟的,可以复用的代码。本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行。库有两种:静态库和动态库。
2、静态库与动态库的区别
(1)静态库
链接时会被完整的复制到可执行文件中,被多次使用就有多分拷贝。如下图,抖音和微信的可执行文件加载静态库时,每个可执行文件链接时都要加载这份静态库。(2)动态库
系统的动态库与我们自己打包的动态库还不大一样,先来看一下系统的动态库。
系统动态库:
链接时不复制,程序运行时由系统动态加载到内存,系统只加载一次,多个程序共用,节省内存。
例如下图:抖音和微信的可执行文件加载动态库时,内存中只有一份动态库,不用加载到可执行文件。
自己打包的动态库:
自己打包的动态库,则是在应用程序里的,但是与静态库不同,它不在可执行文件中。
三、制作静态库与动态库
1、制作静态库
我们在 iOS 下能创建的静态库分两种,分为 .a 和 .framework 两种。
1、制作 .a 静态库
(1)创建
首先创建一个工程,选择为 Static Library 类型。
(2)编译
然后我们在 Products 下就可以看到一个 .a 文件,但是现在它还是不存在的,需要我们 command+B 编译一下,就可以找到它了,由于我们是在模拟器下编译的,所以它生成在 “Debug-iphonesimulator” 文件夹下。
如果添加了新的 .h 文件,需要在 Phases 中把头文件加上,此处 FanjiduoStatic.h 是创建工程时默认加进去了。
然后它会自动把你的头文件放到 include 里面
2、制作 .framework 静态库
(1)首先创建一个工程,选择为 Framework 类型。
创建好发现是 .framework 结尾了
(2)这里要设置一下,因为默认是动态库,要改为静态库。Build Settings => Mach-O Type 改为 Static Library:
3、测试静态库
(1)编写测试类
首先编写了一个 Student 类,实现了一个 study 的打印方法,
然后把 Student 类 import 进了 FanjiduoFrameworkTest.h 总的头文件里面。
(2)公开头文件
然后在 build Phases => Headers 中把头文件公开,从默认的 Project 中拖拽到 Public 中:
然后再编译一下,就大功告成了。
(3)测试
建立一个名为 staticTestDemo 的工程引入 framwork 试一下,发现可以成功调用 study 方法!
2、制作动态库
(1)制作步骤
动态库有很多种,目前像 .tbd .dylib 这种的动态库我们无法打包,只能打包 .framework 格式的动态库。
系统默认设置的就是动态类型,然后就是将新添加的头文件公开,整个流程和 .framework 静态库一样,这里就不再赘述了。
(2)测试
创建一个项目来测试一下这个动态库,直接拖入工程,引入头文件,调用动态库中的方法,然后编译,编译通过没问题。
但是当我们运行的时候,会报下面的错误:
其实这是因为没有将它添加到 Embedded 中,在老板的 Xocde 中,Embedded 是单独设置的,但是不知道从那一版 Xocde 开始,Embedded和其他设置合并在一起了。现在我们只需要在 "General => Frameworks, Libraries, and Embedded Content" 中,把 "Do Not Embed" 改为 "Embed & Sign" 即可,如下图:
然后就可以正常运行了!
以上就是对静态库和动态库的简单介绍,还有打包的流程,希望在你需要的时候可以帮到你!
转载请备注原文出处,不得用于商业传播——凡几多