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

  • 相关阅读:
    [java] 深入理解内部类: inner-classes
    [java] 更好的书写equals方法-汇率换算器的实现(4)
    [java] 注释以及javadoc使用简介-汇率换算器的实现-插曲3
    [java] jsoup使用简介-汇率换算器实现-插曲2
    [java] 汇率换算器实现(3)
    [java] 汇率换算器实现-插曲1-正则表达式(1)
    [java] 汇率换算器实现(2)
    [java] 汇率换算器实现(1)
    [Basic] The most basic things about java
    电路相关知识–读<<继电器是如何成为CPU的>>
  • 原文地址:https://www.cnblogs.com/lesten/p/14286543.html
Copyright © 2020-2023  润新知