gpt4 book ai didi

c - 将已编译代码与 NASM 和 MSVC 链接时未解析的引用

转载 作者:太空宇宙 更新时间:2023-11-03 23:21:20 25 4
gpt4 key购买 nike

我正在尝试将程序集(使用 yasm 编译)与使用 msvc/cl.exe 编译的对象结合起来,我是尝试链接(使用 link.exe)到 .dll,然后链接到最终的可执行文件。

从源代码创建对象文件和从这些对象创建 dll 都工作得很好。

在最后一步中,将 .dll 与可执行文件链接会出现以下错误:

 error LNK2019: unresolved external symbol xxx_xxxx

我正在使用 C。尽管 Win64 没有名称修改,但我尝试了多种方案(例如 _xxx_xxxx__imp_xxx_xxxx)。

使用 dumpbin.exe 检查目标文件会显示所有符号:

$ dumpbin /symbols myobj.o
File Type: COFF OBJECT

COFF SYMBOL TABLE
000 00000000 DEBUG notype Filename | .file

002 00000000 SECT1 notype Static | .text
Section length 215, #relocs 0, #linenums 0, checksum 0
004 00000057 SECT1 notype External | xxx_xxxx
005 0000013E SECT1 notype External | xxx_xxxx
006 00000000 SECT1 notype External | xxx_xxxx

但不在 .dll 的导出符号中:

$ dumpbin /exported mylib.dll
File Type: DLL

Section contains the following exports for mylib.dll

00000000 characteristics
57A0FE02 time date stamp Tue Aug 02 22:09:38 2016
0.00 version
1 ordinal base
132 number of functions
132 number of names

[...]

尽管我已使用 __declspec(dllexport) 将声明标记为在 .dll 中导出。

有什么想法可以让链接器满意并告诉他符号确实存在吗?

最佳答案

如您所见,问题是 DLL 没有公开所需的符号。 __declspec(dllexport) 不是导出符号的唯一方法。如果你有一些导出的名字,你可以使用 /EXPORT链接器开关。另一种选择是使用 Module-Definition文件。

关于c - 将已编译代码与 NASM 和 MSVC 链接时未解析的引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38729747/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com