[iOS-Release] Build Settings

Build settings reference

Preprocessor Macros

可针对不同的构建配置设置相应的预处理宏,在代码中即可根据相应的宏来判断当前执行的构建配置,然后执行相应的代码

#ifdef DEBUG

#elif DEMO

#else

#endif

Precompile Prefix Header

说明是否为 Target 创建一个预编译头文件,新项目要主动添加预编译头文件时,该项需设置为 Yes。

Prefix Header

Target 预编译头文件的路径。

Other Linker Flags

源代码需要经过预处理,编译,链接后最终生成可执行文件。在将多个 .obj 文件链接起来时,就会用到 ld 命令,即 XCode 的链接器。而
Other Linker Flags 设置的就是 ld 命令的参数,它的3个常用参数为

  1. -ObjC,链接器会把静态库中所有的Objective-C类和分类都加载到最后的可执行文件中。在开发过程中,有时候会用到第三方的静态库(.a文件),然后导入后发现编译正常但运行时会出现selector not recognized的错误,从而导致app闪退。而原因和Objective-C的一个重要特性:类别(category)有关。Unix的标准静态库实现和Objective-C的动态特性之间有一些冲突:Objective-C没有为每个函数(或者方法)定义链接符号,它只为每个类创建链接符号。这样当在一个静态库中使用类别来扩展已有类的时候,链接器不知道如何把类原有的方法和类别中的方法整合起来,就会导致你调用类别中的方法时,出现"selector not recognized",也就是找不到方法定义的错误。为了解决这个问题,引入了-ObjC标志,它的作用就是将静态库中所有的和对象相关的文件都加载进来。当静态库中只有分类而没有类的时候,-ObjC参数就会失效了。这时候,就需要使用-all_load或者-force_load了。
  2. -all_load,链接器会把所有找到的目标文件都加载到可执行文件中,但是千万不要随便使用这个参数!假如你使用了不止一个静态库文件,然后又使用了这个参数,那么你很有可能会遇到ld: duplicate symbol错误,因为不同的库文件里面可能会有相同的目标文件,所以建议在遇到-ObjC失效的情况下使用-force_load参数。
  3. -force_load,所做的事情跟-all_load其实是一样的,但是-force_load需要指定要进行全部加载的库文件的路径,这样的话,你就只是完全加载了一个库文件,不影响其余库文件的按需加载

你可能感兴趣的:([iOS-Release] Build Settings)