-
-ObjC
链接器就会把静态库中所有的 Objective-C 类和分类都加载到最后的可执行文件中。
这样编译之后的 app 会变大,因为加载了很多不必要的文件而导致可执行文件变大。但是如果静态库中有类和 category 的话只有加入这个 flag 才行。但是 Objc 也不是万能的,当静态库中只有分类而没有类的时候,Objc 就失效了,这就需要使用 -all_load 或者 -force_load 了。
@implementation MyStaticLib + (void)test { NSLog(@"sssss"); } @end @implementation MyStaticLib (Cate) /** * 重写方法 */ + (void)test { NSLog(@"哈哈哈"); } @end
静态库中分类重写了方法,导入工程中,设置 -Objc 参数将打印:哈哈哈;不设置将打印:sssss。
-
-all_load
会让链接器把所有找到的目标文件都加载到可执行文件中,即使没有 objc 代码。但是这个参数也有一个弊端,假如你使用了不止一个静态库文件,然后又使用了这个参数,那么你很有可能会遇到 ld: duplicate symbol 错误,因为不同的库文件里面可能会有相同的目标文件,有两种方法解决:1、用命令行进行拆包;2、使用 -force_load 参数。
-
-force_load
适用于 Xcode3.2+ 版本,它允许 finer 得到文档加载的控制,所做的事情跟 -all_load 其实是一样的,但是每一个 -force_load 操作必须跟着一个文档路径,文档中的每一个对象文件将会被加载,这样的话,你就只是完全加载了一个库文件,不影响其余库文件的按需加载。
-
-lstdc++
OC 和 C++ 混编时,在 Compile 阶段一切顺利,Clang 会根据后缀(.m .cpp)选择编译器进行编译,产物都是 Object File(.o 文件)。如果一个文件调用另一个文件的方法,编译出的 Object File 中会出现 undefined symbol 去代表这个方法。在链接阶段,Linker 通过把依赖的文件也加到最终的 executable 中 resolve undefined symbol。
Linker 没有主动的去 link stdc++ 库,解决方案 1:在 Other Linker Flags 中新增标志 -lstdc++;解决方案2:在 Linked Framework and Libraries 中添加 libstdc++.tbd。
-
总结:
建议 -ObjC 与 -force_load 搭配使用比较好。
包含静态库时需要在 Target 的 Other linker flags 里面加上值:-objC、-all_load、-force_load
对于 64 位机器和 iPhone O S应用,解决方法是使用 -all_load 或者 -force_load。
在Xcode4.2之后,这个链接器bug已经被修复,因此-all_load 和 -force_load标志都不再需要了。在必要时添加-ObjC即可。
转载自: https://www.cnblogs.com/dins/p/xcode.html