参考:http://www.cnblogs.com/cassvin/archive/2011/07/24/Linux_Qtopia_2.html
详情点击: 原文
linux下编译应用程序常常会出现如下错误:
/usr/bin/ld: cannot find -lxxx
意思是编译过程找不到对应库文件。其中,-lxxx表示链接库文件 libxxx.so。
注:有时候,由于库文件是编译过程临时生成的,如果前面出错也会导致出现这种情况,下面针对的是由于本机系统环境缺失而引起的。。
一般出现这种错误有以下几种原因:
1.系统缺乏对应的库文件;
2.版本不对应;
3.库文件的链接错误;
4.库文件路径设置问题;
对应第一第二种情况,可以通过下载安装lib来解决,ubuntu大多数可以直接通过apt-get来安装:
apt-get install libxxx-dev
一般遇到这种问题笔者第一时间也是会去检查系统是否已安装该lib或者是否已选择正确版本(只是习惯问题),如果还是不能解决问题,那么,引起错误的原因不是链接错误就是库文件路径问题了。
通过find或者locate指令定位到链接文件,查看链接文件是否正确的指向了我们希望的lib,如果不是,用 ln -sf */libxxx.so.x */libxxx.so 指令修改它。
如果是库文件路径引发的问题,可以到/etc/ld.so.conf.d目录下,修改其中任意一份conf文件,(可以自建conf,以方便识别)将lib所在目录写进去,然后在终端输入 ldconfig 更新缓存。
还有刚遇到的问题。升级安装了一个库,它把链接改了。卸载了之后,又重装干了些活。编译一个新库时,总是提示 libssl libcrypto /usr/bin/找不到。一直以为是版本问题,有两个库文件啊,怎么可能找不到。不过 ld 怎么找的真不知道 。看了上文有所启发。再仔细一看没有链接。试着改了一个就少了一个错误。都增加链接后,编译就通过了。也就是库找到了。
Ubuntu 自动安装卸载,还会出现这个问题啊。长见识了。
看来 /usr/bin/ld 是根据系统库路径里面的链接找到对应的库的。如 Makefile 里 -lcrypto 会以这样的顺序去找 /lib/x86_64-linux-gnu/libcrypto.so -> /lib/x86_64-linux-gnu/libcrypto.so.0.9.8
快乐在于分享。。。