【IOS】关于cocopods更新第三方库报ld: library not found for -lXXXXXX错误

昨天更新项目第三方库出现了Undefined symbols for architecture x86_6(arm64)错误,有关于这个错误的请查看上一篇文章,话题至此咱们看看今天得问题。

今天我更新更新的是另一个项目的第三方类库SDK,更新完之后报ld: library not found for -lXXXXXX,这个错误是说编译时找不到XXXXXX这个链接库,但是我在项目代码中找到对引用的地方,没有其他异常。有三种解决方法。

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

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

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

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

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

但是这三种方法都不适用,因为更行的第三方库Podfile 文件中的地址修改了导致之前的导入的类库名字没有删除而找不到,所以只能是又找的其他方法是工程运行的Target ---> Build Setting--->Other Linke Flags 把找不到的类库名字删除就可以了。
当然也有可能是倒入库没有加进去,根据自己的实际情况进行处理,一般上述的是三种方法就可以解决大部分问题。

你可能感兴趣的:(【IOS】关于cocopods更新第三方库报ld: library not found for -lXXXXXX错误)