关于XCode链接选项 -ObjC -all_load -force_load(转载)

  • -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

原文地址:https://www.cnblogs.com/lesten/p/14286543.html