(原创)ld: library not found for -lXXXXX 编译问题的解决方法

ld: library not found for -lXXXXX   的解决方法

    团队开发的时候每次更新后都有可能碰到各种各样的问题,昨天同事对项目结构做了些修改,更新后编译就遇到下面的情况:

    ld: library not found for -lAFNetworking  这个错误是说编译时找不到AFNetworking这个链接库,但是我在项目代码中找到对引用的地方,没有其他异常。从网上搜索找到两种解决方法。

    方法一点击 XCode 工程文件,在 Build Phases 中查看 “ Link binary With Libraries”  

如果不出所料,你应该能发现有一到数个的条目是用红色字体来显示的。 
说明这些被工程引用的这些文件,其物理文件已经不处于之前所记录的地方了。 
这种情况下,右键点击红色条目,选择 “Reveal in Project Navigator” 
此时大抵能在左侧栏中定位到缺失文件所在的路径,接下来就好办了,找到缺失的文件,挪回它应该待的地方。

    方法二在工程的 Target 中选中要执行编译的某个target 然后 “get info”,打开 Build 设置页面,在Library Search Path中添加缺失链接库的所在文件夹的路径。

    本来看到这两种方法时觉得第一种应该就能解决了,因为报错的信息看起来就像是原来的文件引用不到了而已,但是当我按照第一种方法去做时,发现“ Link binary With Libraries” 下没有红色的条目,而且本来就没有AFNetworking这个条目,所以第一种方法不适用。第二种方法也不对,因为我们的项目很多库是通过pod管理的,AFNetworking也是pod管理的库之一。这时候我就想起可能是pod的原因,在尝试了pod update无果后,发现了第三种解决类似问题的方法。

    方法三:关闭Xcode,在控制台打开到工程目录,用pod install 命令重新安装,成功后再打开Xcode编译项目。

    最后,第三种方法解决了我遇到的问题。但是为什么为出现这种错误呢?以前遇到需要类库有版本升级、类库有删减,使用pod update命令就可以了,而需要重新pod install的情况很少。我又对比了更新前后两个版本的Podfile,发现也没有不同,也就是说问题不是由于Podfile变化引起的。又度娘加谷哥了半天,也没找到相关解释。

    总结来说,上面三种方法应该都可以解决部分情况,但是不同情况下问题产生的原因是一样的。第一、二种方法比较好解释原因,第三种方法,即pod install,为什么能解决问题我现在还不太明白。希望遇到知道的同学能帮忙解释下。

    转载请注明出处 灰烬里有颗心的博客 http://grayheart.iteye.com 。 

猜你喜欢

转载自grayheart.iteye.com/blog/2277584