/usr/bin/ld: cannot find -lxxx 问题总结

参考: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



快乐在于分享。。。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值