iOS静态库与动态库的区别与打包

2021-02-03 16:58:39

参考地址 iOS静态库与动态库的区别与打包

一、前言

这篇主要是记录一下 iOS 下静态库与动态库的打包流程,以便以后用到时快速查阅,供自己也供大家学习记录。同时也简述了一下 动态库静态库 的区别。

二、静态库与动态库

1、库

库是写好的现有的,成熟的,可以复用的代码。本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行。库有两种:静态库动态库

2、静态库与动态库的区别

(1)静态库

链接时会被完整的复制到可执行文件中,被多次使用就有多分拷贝。如下图,抖音和微信的可执行文件加载静态库时,每个可执行文件链接时都要加载这份静态库。


(2)动态库

系统的动态库与我们自己打包的动态库还不大一样,先来看一下系统的动态库。

系统动态库:链接时不复制,程序运行时由系统动态加载到内存,系统只加载一次,多个程序共用,节省内存。 例如下图:抖音和微信的可执行文件加载动态库时,内存中只有一份动态库,不用加载到可执行文件。


自己打包的动态库:自己打包的动态库,则是在应用程序里的,但是与静态库不同,它不在可执行文件中。


三、制作静态库与动态库

1、制作静态库

我们在 iOS 下能创建的静态库分两种,分为 .a.framework 两种。

1、制作 .a 静态库

(1)创建

首先创建一个工程,选择为 Static Library 类型。


(2)编译

然后我们在 Products 下就可以看到一个 .a 文件,但是现在它还是不存在的,需要我们 command+B 编译一下,就可以找到它了,由于我们是在模拟器下编译的,所以它生成在 “Debug-iphonesimulator” 文件夹下。

静态库最新.png


如果添加了新的 .h 文件,需要在 Phases 中把头文件加上,此处 FanjiduoStatic.h 是创建工程时默认加进去了。

然后它会自动把你的头文件放到 include 里面


2、制作 .framework 静态库

(1)首先创建一个工程,选择为 Framework 类型。


创建好发现是 .framework 结尾了


(2)这里要设置一下,因为默认是动态库,要改为静态库。Build Settings => Mach-O Type 改为 Static Library:


3、测试静态库

(1)编写测试类

首先编写了一个 Student 类,实现了一个 study 的打印方法, 然后把 Studentimport 进了 FanjiduoFrameworkTest.h 总的头文件里面。


(2)公开头文件

然后在 build Phases => Headers 中把头文件公开,从默认的 Project 中拖拽到 Public 中:

然后再编译一下,就大功告成了。


(3)测试

建立一个名为 staticTestDemo 的工程引入 framwork 试一下,发现可以成功调用 study 方法!


2、制作动态库

(1)制作步骤

动态库有很多种,目前像 .tbd .dylib 这种的动态库我们无法打包,只能打包 .framework 格式的动态库。 系统默认设置的就是动态类型,然后就是将新添加的头文件公开,整个流程和 .framework 静态库一样,这里就不再赘述了。

(2)测试

创建一个项目来测试一下这个动态库,直接拖入工程,引入头文件,调用动态库中的方法,然后编译,编译通过没问题。 但是当我们运行的时候,会报错误 "Reason:image not found",如下图:

其实这是因为没有将它添加到 Embedded 中,在老版本的 Xocde 中,Embedded 是单独设置的,但是不知道从那一版 Xocde 开始,Embedded 和其他设置合并在一起了。现在我们只需要在 "General => Frameworks, Libraries, and Embedded Content" 中,把 "Do Not Embed" 改为 "Embed & Sign" 即可,如下图:
然后就可以正常运行了!


作者:凡几多
链接:https://juejin.cn/post/6844903992082825224
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。


  • 2020-05-20 22:29:05

    javascript中为何在匿名function函数后面还外加

    它可以解释成为“匿名函数自调用”,也就是说,定义一个匿名函数,然后马上调用它(因为它是匿名的,如果不立即调用就获取不到该函数的引用了)。通常它被应用在一些大型的JS框架中(如上面所说的),因为这个匿名函数的函数体相当于提供一个匿名的名字空间,这样就不会再与用户自定义的JS函数、变量、对象发生冲突了。尽管JS没有显示地提供命名空间的定义和使用机制,但这种匿名方式却不失为是一种很好的解决命名空间问题的方法。

  • 2020-05-20 22:30:14

    js中利用prototype给类添加方法

    你可能会想,这不就是个简单的函数声明?没错,这个函数就是一个类的定义的实现。如何使用这个类呢?看下面的代码:var cls1 = new MyClass(); 这样,利用new就可以生成MyClass的一个实例了。所以在js中可以说函数就是类,类就是函数。

  • 2020-05-21 10:56:53

    fixed z-index失效

    作为一个假的前端,在调试一个页面时出现了如下bug。 左侧的菜单固定为fixed时,二级菜单无法设置有效的z-index,导致菜单隐藏在页面元素之下,明明页面元素的z-index是1,但是无论把菜单的z-index设置为多大,都不管用。

  • 2020-05-24 08:10:18

    echarts标题(title)配置

    show:true,//显示策略,默认值true,可选为:true(显示) | false(隐藏) text: '主标题',//主标题文本,'\n'指定换行 link:'',//主标题文本超链接,默认值true target: null,//指定窗口打开主标题超链接,支持'self' | 'blank',不指定等同为'blank'(新窗口) subtext: '副标题',//副标题文本,'\n'指定换行 sublink: '',//副标题文本超链接