.frameworke静态库的制作
1、先创建一个新的Xcode工程LibTest,需要选择下面这个模板:
创建完成后是这个样子的:
创建完成后我们可以看到,工程本身自带一个LibTest.h
文件和一个Info.plist
文件。
2、我们创建一个类PrintString
,添加一个单纯打印字符串的简单方法:
3、选择添加公开头文件
为了让使用者知道有哪些方法可以用,我们需要公开头文件,我们需要在 并且将Target->Build Phases->Headers
中的Projec
t中要暴露的头文件拖拽到Pulic
里面,这里我们公开PrintString.h
:
4、设置支持所有架构(和.a制作一样)
5、修改生成的Mach-O
格式,因为动态库也可以是以framework形式存在,所以需要设置,否则默认打出来的是动态库。将target->BuildSetting->Mach-o Type
设为Static Library
(默认为Dynamic Library
):
我们分别选择Generic iOS Device
和任意一个模拟器
各编译一次,编译完后,我们会看到工程中Products文件夹下的LibTest.framework由红色变成了黑色,然后show in finder
,看看生成的文件:
我们看到它为真机和模拟器都生成了LibTest.framework静态库。
我们来查看静态库支持的框架:与上面不同,命令为lipo -info framework下的二进制文件名字
lipo -create 第一个framework下二进制文件的绝对路径 第二个framework下二进制文件的绝对路径 -output 最终的二进制文件路径
:
然后将任何一个framework中的二进制文件替换成合并后的二进制文件,然后把framework添加到要使用的项目中即可使用。
使用生成的.framework静态库
新建一个工程,将静态库拖进去,导入头文件,就可以使用里面的方法了。经过试验,我们生成的静态库在真机上和模拟器上都能成功打印字符串:
注意:
如果静态库中有category类,则在使用静态库的项目配置中Other Linker Flags
需要添加参数-ObjC
或者-all_load
。
如果创建的framework类中使用了.tbd
,则需要在实际项目中导入.tbd
动态库。
运行调试静态库
如果你是开发静态库的人,你会发现上面的方法只是制作静态库,并没有办法运行看效果和调试bug,这时候我们可以这样:
1、新建一个专门用来开发静态库的正常工程Test:
2、添加一个静态库的target
我们看到它生成了几样东西:
一个framework的target:在这里面修改静态库的配置们,例如支持的架构、要暴露的头文件们和Mach-O的配置。
一个LibTest文件夹:静态库里面的类们都放在这里面。
product文件夹下面的LibTest.framework:在这里show in finder找到编译后生成的静态库。
3、开发调试代码
我们看到程序可以正常运行,并可以在动态库里面蹲点运行。方便我们调试。
4、确保代码没问题后,选择对应的target编译生成。