在iOS开发中经常遇到一些关于路径的设置,比如引入了百度地图的SDK,项目拷贝到其他的电脑上或者多人同时开发的时候容易报Library Not Found的错误,或者是引入第三方库比如ASIHttpRequest/RETableView经常报#include <>的错误这就需要配置一些搜索路径。

Framework/Library Search Paths
1、Framework Search Paths
附加到项目中的framework(.framework bundles)的搜索路径,在iOS开发中使用的不是特别多,通常对于iOS的开发来说一般使用系统内置的framework。
2、Library Search Paths
附加到项目中的第三方Library(.a files)的搜索路径,Xcode会自动设置拖拽到Xcode中的.a文件的路径,为了便于移植或者是多人协作开发一般会手动设置。
比如对于设置百度的地图的SDK,我们会设置如下:
$(SRCROOT)/../libs/Release$(EFFECTIVE_PLATFORM_NAME),其中
$(SRCROOT)宏代表您的工程文件目录,$(EFFECTIVE_PLATFORM_NAME)宏代表当前配置是OS还是simulator
Header Search Path
1、C/C++头文件引用
在C/C++中,include是变异指令,在编译时,编译器会将相对路径替换成绝对路径,因此,头文件的绝对路径等同于搜索路径+相对路径。
(1)#include <iostream.h>:引用编译器的类库路径下的头文件
(2)#include "hello.h":引用工程目录的相对路径的头文件
2、(User) Header Search Path
(1)Header Search Path指的是头文件的搜索路径。
(2)User Header Search Paths指的是用户自定义的头文件的搜索路径
3、Always Search User Paths
如果设置了Always Search User Paths为YES,编译器会优先搜索User Header Search Paths配置的路径,在这种情况下#include <string.h>,User Header Search Paths搜索目录下面的文件会覆盖系统的头文件。
常见配置
1、libxml/tree.h not found的错误配置
在build setting中的header search path中加入${SDK_DIR}/usr/include/libxml2