.frameworke静态库的制作及使用

1、先创建一个新的Xcode工程CommonKit2,需要选择下面这个模板:
.frameworke静态库的制作及使用_第1张图片
2、添加自己要封装的文件
.frameworke静态库的制作及使用_第2张图片
3、添加公开头文件
Target->Build Phases->Headers中的Project中要暴露的头文件拖拽到Pulic里面:
.frameworke静态库的制作及使用_第3张图片

4、设置支持所有架构(和.a制作一样)
Build Active Architecture Only都设置NO

5、修改Mach-O格式:Target->BuildSetting->Mach-o Type 设为Static Library;
因为Xcode生成的framework默认是Dynamic Library动态库,苹果禁止使用动态库上架。

.frameworke静态库的制作及使用_第4张图片
6、编译
分别选择Generic iOS Device和任意一个模拟器各编译一次。编译完,工程中Products文件夹下的CommonKit2.framework由红色变成了黑色,然后show in finder,看看生成的文件
.frameworke静态库的制作及使用_第5张图片
真机和模拟器都生成了CommonKit2.framework静态库。

终端命令格式:

//命令查看静态库支持的指令集(与.a不同,命令处理的是framework下的二进制文件名字):
lipo -info framework静态库下的二进制文件绝对路径(即上图箭头所指)
//命令合并模拟器和真机的静态库,然后将任何一个framework中的二进制文件替换成合并后的二进制文件即可:
lipo -create 第一个二进制文件的绝对路径  第二个二进制文件的绝对路径 -output 最终的文件路径

好了,这样就创建好.framework静态库了,使用的时候,只需在工程中导入.framework文件,配置Header search path路径就可以了。

总结:Build Phases设置暴露的头文件 - 设置支持所有架构 - 修改Mach-O - 编译(命令行合并)
注意:
如果静态库中有category类,则在使用静态库的项目配置中Other Linker Flags需要添加参数-ObjC或者-all_load。
如果创建的framework类中使用了.tbd,则需要在实际项目中导入.tbd动态库。

测试:(这里仅用模拟器生成的静态库文件,未使用合并后的)
创建新项目,创建了Dependency文件夹及相关静态库文件夹,方便管理;
.frameworke静态库的制作及使用_第6张图片

OK!正常调用了method。

另一种方式,在工程中开发静态库:

你可能感兴趣的:(静态库)