使用vcpkg自动链接tinyxml2时莫名链接其他库(例如boost)

使用vcpkg自动链接tinyxml2时莫名链接其他库(例如boost)

vcpkg的自动链接功能非常方便,但在某些情况下会出现过度链接的问题。

链接错误症状

tinyxml2为例,程序中调用tinyxml2的函数后,若vcpkg中同时存在opencvboost库,自动链接会把本不需要的这两个库的lib也链接上,导致最后生成的可执行程序exe也依赖opencvboost的动态库dll。

主程序:

cpp 复制代码
#include <iostream>
#include <tinyxml2.h>

int main()
{
    tinyxml2::XMLDocument doc;
    std::cout << "Hello World!\n"; 
    return 0;
}

错误链接boost后,由于boost某些头文件还包含了BOOST_DLLEXPORT(也就是__declspec(dllexport))字段,会导致生成.exe的同时还生成.lib和.exp文件,非常烦人:

链接错误原理

vcpkg的自动链接功能是通过遍历所有的.lib文件实现的,为程序引用的符号找到对应依赖库。

上述错误是由于tinyxml2引用的某些函数所引用的函数在其他.lib中首先被找到------即tinyxml2引用的某些函数同时在opencv和boost库中也有定义,遍历时后者的.lib先于tinyxml2.lib被找到,从而导致链接了opencv和boost的.lib文件而未链接tinyxml2.lib,进而仅拷贝了opencv和boost的动态库。

解决方法

对症下药,提供两种方法避免链接错误。

方法一 :不关闭自动链接功能,在链接器-输入中指定tinyxml2.lib链接器-输入指定的库链接优先级高于vcpkg的自动链接,因此链接器首先从tinyxml2.lib中找到了所需函数后,就终止遍历、不再搜索boost或opencv等vcpkg环境中其他lib里的函数表,最后只链接tinyxml2.lib。

方法二 :关闭自动链接功能,在链接器-输入中指定所依赖库的.lib文件。推荐在方法一不奏效时使用。

vcpkg自动链接功能

vcpkg是一个跨平台的c++库工具链,提供了c++库的编译、安装和配置等功能,可以与MSBuild(VS)、CMake等工具集成使用,非常方便。

以VS为例,vcpkg在项目属性中提供了一系列的功能开关,以使用户更方便地使用库:

其中的开关顾名思义,例如"Use Vcpkg"即控制是否在当前项目中使用Vcpkg;"Use AutoLink"控制是否自动链接 项目所需.lib库而不需要手动在链接器-输入中指定。这两个开关默认都是开启状态。

自动链接功能在项目需要依赖包含多个.lib的库时特别有用,例如点云处理算法库pcl
pcl在编译时就需要依赖Boost、Eigen、Vtk等库,编译完成后生成一大堆.lib和.dll。

若没有vcpkg,使用pcl库时更是需要在链接器-输入中按需列上boost、vtk和pcl自身的诸多.lib文件,例如:

为避免重复工作,多数人选择使用项目属性表将上面的配置记录下来,以便后续项目使用。

**但是,**在有了vcpkg之后,链接工作就大大简化了。vcpkg提供的自动链接功能会遍历所有lib文件,找到项目所引用函数后将对应lib自动链接上,不需要用户手动指定链接哪一个lib,非常省心。

并且,在编译生成可执行程序后,vcpkg还会自动将依赖的动态库拷贝到可执行程序所在目录,方便运行。以包含了OpenCV库的项目为例,编译生成的结果如下图所示:

可见,opencv的一系列动态库和依赖的jpeg、png库都被拷贝到exe旁边了。

相关推荐
天若有情6735 小时前
【自研实战】轻量级ASCII字符串加密算法:从设计到落地(防查岗神器版)
网络·c++·算法·安全·数据安全·加密
凯子坚持 c5 小时前
CANN 性能剖析实战:从原始事件到交互式火焰图
windows·microsoft
czy87874755 小时前
深入了解 C++ 中的 `std::bind` 函数
开发语言·c++
我在人间贩卖青春5 小时前
C++之继承的方式
c++·private·public·protected·继承方式
开开心心就好6 小时前
发票合并打印工具,多页布局设置实时预览
linux·运维·服务器·windows·pdf·harmonyos·1024程序员节
獨枭6 小时前
PyCharm 跑通 SAM 全流程实战
windows
仙剑魔尊重楼6 小时前
音乐制作电子软件FL Studio2025.2.4.5242中文版新功能介绍
windows·音频·录屏·音乐·fl studio
智者知已应修善业7 小时前
【洛谷P9975奶牛被病毒传染最少数量推导,导出多样例】2025-2-26
c语言·c++·经验分享·笔记·算法·推荐算法
Trouvaille ~7 小时前
【Linux】应用层协议设计实战(一):自定义协议与网络计算器
linux·运维·服务器·网络·c++·http·应用层协议
CSCN新手听安7 小时前
【linux】高级IO,I/O多路转接之poll,接口和原理讲解,poll版本的TCP服务器
linux·运维·服务器·c++·计算机网络·高级io·poll