链接器踩坑

本文记录了一次因SDK更新引发的库冲突问题,引发了对链接器工作原理的探讨。通过实验发现,链接器按指定顺序遍历库文件查找符号,选择最先遇到的实现,而不是所有相同符号的合并。这解释了库交换顺序导致的不同链接结果,并证实了链接器未记录库中符号的细节。

在工作中遇到一次,项目更新一个sdk的后,发现另一个没有改动的sdk提供的功能无法生效了。仔细排查后,发现是因为升级后的sdk包含了与另一个已有sdk同名的库(大概率内部一些接口也是一致的),猜测这里出了问题。遂对链接器的一些实现产生了好奇,做了一个简单的实验,这里记录一下。

对链接器的一些疑问

  • 从经验看,CMakeLists文件只是简单的使用target_link_libraries之类的接口添加一个project需要链接的库,却没有任何地方指明了更进一步的链接细节,比如某个class A需要到具体的a.lib里面去寻找定义。那么势必导致两个结果:
    • lib的名字不影响具体的链接。如果一个project同时链接了a.libb.lib,那么交换ab的名字,不应该影响链接结果(这里以交换文件名距离,是因为需要保证改名后的lib仍然是可以被定位到的。直接把a.lib改成a1.lib可能会找不到)
    • 符号是通过遍历库来查找的。因为并没有任何一个统一的表,注明了各个待链接的库包含了哪些符号,那么链接想想查找某个符号的时候,唯一可行的办法只有通过遍历各个库,查看是否有声明的符号。
    • 在上一条的背景下,如果多个库里含有相同的符号,那具体链接器会怎么做,其实是不一定的了(取决于链接器的实现)。下面这个实验就验证了这一点。

代码

目录结构
src
├── CMakeLists.txt
├── main.cpp
├── mylib1
|   ├── CMakeLists.txt
|   ├── test.cpp
├── mylib2
|   ├── CMakeList
### 常见问题及解决方法 #### 无法打开Anaconda Navigator (Anaconda3) 当遇到此情况时,可能是由于路径设置不当或是某些依赖库缺失所引起。尝试通过命令行运行`anaconda-navigator`来启动Navigator可以提供更详细的错误信息帮助定位问题[^1]。 对于Windows用户而言,如果是在安装后首次尝试开启却失败,则可能是因为环境变量未被正确添加到系统中。此时应确认Anaconda的安装选项里选择了将路径加入环境变量这一项;另外重启计算机也是一个简单有效的措施让新的环境变量生效[^2]。 #### CondaHTTPError: HTTP 000 CONNECTION FAILED for URL 此类网络连接类错误表明Conda试图访问远程服务器但是未能成功建立联系。这通常是短暂性的网络波动造成的,在几分钟后再试一次往往能够解决问题。除此之外还可以考虑更改镜像源至国内站点如清华TUNA镜像加速下载速度并提高稳定性: ```bash conda config --add channels https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud/msys2/ conda config --set show_channel_urls yes ``` 上述命令会向渠道列表追加一个新条目,并启用显示频道网址的功能方便调试[^4]。 #### anaconda ImportError: cannot import name 'HTTPSHandler' 该异常多发生在不同版本间的兼容性冲突之上。“six”模块是一个支持Python 2和3之间代码转换的小型库,而其内部结构的变化可能会引发这类导入错误。更新`six`以及相关联的软件包可作为初步处理手段: ```bash conda update six urllib3 chardet certifi idna requests ``` 以上指令旨在同步升级一系列涉及网络请求处理的基础组件以确保它们处于最新状态从而减少潜在矛盾点。 #### Anaconda 加入系统变量 CMD命令提示符闪退打不开 VSCode 中无法启动 Conda 环境 这些现象均指向了相似的根本原因——即环境配置出现了偏差。具体来说就是PATH等重要环境参数丢失或者是存在重复定义干扰到了正常解析流程。建议重新执行Anaconda Installer并且勾选有关自动调整环境变量的相关选项完成修复工作。与此同时注意清理旧有的残留记录以免造成混淆。 此外,针对VS Code集成开发环境下的特殊状况,还需额外验证扩展插件是否已经按照官方文档说明进行了适当设定,特别是关于解释器选择的部分要特别留意确保指定了正确的虚拟环境位置[^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值