vs工程中链接lib库注意事项

本文总结了在使用VS2010进行程序调试过程中遇到的无法解析外部符号问题,列举了十种可能的原因及其解决方案,如检查lib文件是否匹配、确保类声明与实现的一致性等。

在使用vs2010调试程序的过程中,经常会出现无法解析的外部符号问题,可能的原因有很多种,下面这些是我一年来积累的经验.

仅供参考.

考虑可能的原因:
[0]出现无法解析可能是因为lib文件不正确,比如64位的编译配置,结果使用的是32位的lib包.
[1]只写了类声明,但还没有写实现类,造成调用时无法解析
[2]声明和定义没有统一,造成链接不一致,无法解析
[3]没有在项目属性页的链接器的命令行选项加入相应的类包。
[4]没有在c++包含目录和库目录加入相应的类包路径
[5]在测试工程中被测文件目录可能需要包含被测类的cpp定义文件
[6]ICE接口测试时,无法解析可能因为被测文件没有包含进相关的cpp文件,另外,在TestSuite_ProjectRun.h文件中需要包含IProjectRun.h头文件,及相关的头文件(举例)。

[7]import相关的无法解析内容,解决办法是在链接器的依赖项中加入相应的动态库

[8]出现如下错误的原因一般是动态库没有包进来。__imp
ProjectRun.obj : error LNK2019: 无法解析的外部符号 __imp__StartHistoryLocalModule,该符号在函数 "protected: virtual int __thiscall HiRTDB::CProjectRun::DoStart(void)" (?DoStart@CProjectRun@HiRTDB@@MAEHXZ) 中被引用

[9]error LNK2001: 无法解析的外部符号 __imp___CrtDbgReportW
工程属性,C/C++,代码生成,运行库跟lib库工程要一致


[10]无法解析的外部符号"__declspec(dllimport) public: int __thiscall HiRTDB::CTagTree::GetObjectA(int,struct HiRTDB::SBaseReadProps const &,struct HiRTDB::SBaseReadValues &)" (__imp_?GetObjectA@CTagTree@HiRTDB@@QAEHHABUSBaseReadProps@2@AAUSBaseReadValues@2@@Z),该符号在函数"public: int __thiscall HiRTDB::CStringImpl::Get(int,struct HiRTDB::SStringReadProps const &,struct HiRTDB::SStringReadValues &)" (?Get@CStringImpl@HiRTDB@@QAEHHABUSStringReadProps@2@AAUSStringReadValues@2@@Z) 中被引用

原因可能是工程配置文件中有多余选项,请参考其他模块的配置选项,不要有多余配置。


在 Visual Studio 2019 中链接动态(DLL)通常包括两个主要部分:创建 DLL 项目以及在另一个可执行项目中使用该 DLL。以下是一个完整的示例流程,涵盖从 DLL 创建到其使用的全过程。 --- ### 创建动态链接(DLL) 1. 打开 **Visual Studio 2019**,点击 "创建新项目"。 2. 在模板列表中选择 **动态链接 (DLL)** 模板,并命名为 `DemoDll`,然后点击“创建”。 3. 添加以下代码来定义导出函数: #### 文件:`DemoDll.h` ```cpp #pragma once #ifdef DEMODLL_EXPORTS #define API extern "C" __declspec(dllexport) #else #define API extern "C" __declspec(dllimport) #endif API int add_array(int* pArr, int nLen); ``` #### 文件:`DemoDll.cpp` ```cpp #include "pch.h" #include "DemoDll.h" int add_array(int* pArr, int nLen) { int sum = 0; for (int i = 0; i < nLen; ++i) { sum += pArr[i]; } return sum; } ``` 4. 构建项目以生成 `DemoDll.dll` 和 `DemoDll.lib` 文件。 --- ### 使用动态链接的可执行程序 1. 向解决方案中添加一个新项目: - 右键点击解决方案资源管理器中的解决方案 -> "添加" -> "新建项目"。 - 选择 **控制台应用程序** 模板,命名为 `UseDemoDll`。 2. 配置项目依赖关系: - 右键点击 `UseDemoDll` 项目 -> "属性" -> "通用属性" -> "添加新引用" -> 选择 `DemoDll` 项目。 3. 编写主程序代码: #### 文件:`UseDemoDll.cpp` ```cpp #include <iostream> #include <Windows.h> typedef int (*LPDO_ARRAY)(int*, int); int main() { HINSTANCE hDll = LoadLibrary(L"DemoDll.dll"); if (!hDll) { std::cerr << "无法加载 DLL!" << std::endl; return 1; } LPDO_ARRAY lpAddArray = (LPDO_ARRAY)GetProcAddress(hDll, "add_array"); if (!lpAddArray) { std::cerr << "无法找到函数!" << std::endl; FreeLibrary(hDll); return 1; } int arr[] = {1, 2, 3, 4, 5}; int len = sizeof(arr) / sizeof(arr[0]); int result = lpAddArray(arr, len); std::cout << "数组总和为:" << result << std::endl; FreeLibrary(hDll); return 0; } ``` 4. 将生成的 `DemoDll.dll` 文件复制到 `UseDemoDll` 的输出目录(例如 Debug 或 Release 文件夹)。 5. 运行 `UseDemoDll` 项目,应该会看到输出结果。 --- ### 注意事项 - 确保 DLL 和 EXE 的构建平台一致(例如均为 x64 或 Win32)[^2]。 - 如果 DLL 放置于非当前工作目录,请提供完整路径给 `LoadLibrary` 函数。 - 动态链接可以被多个进程共享,适用于模块化设计和资源共享场景[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值