C DLL 导出:修饰/修饰的名称
在 C DLL 开发中,预计导出的函数名称在编译后显示为未修饰。但是,遇到带有附加字符的修饰函数名称可能会引起关注。
修饰的原因
所看到的修饰是编译器名称重整过程的结果。编译 C 代码时,编译器会修改函数名称以确保重载函数或不同编译单元之间的唯一性。此重整包括其他字符和符号。
使用 Pragma Comment 的解决方案
要导出未修饰的函数名称,而不使用模块定义文件,可以插入 pragma 注释:
#pragma comment(linker, "/EXPORT:SomeFunction=_SomeFunction@@@23mangledstuff#@@@@")
或者,获取修饰函数名称自动:
#pragma comment(linker, "/EXPORT:" __FUNCTION__"=" __FUNCDNAME__)
与声明说明符等效的 Extern "C"
另一种方法是使用带有声明说明符的 extern "C":
extern "C" void __declspec(dllexport) SomeFunction();
但是,这个方法仍然会产生相同的装饰函数name.
消除后缀
不幸的是,如果不使用模块定义文件或编译注释,则无法消除后缀“=”修饰。此后缀表示函数的修饰版本。
C# 应用程序的解决方法
虽然首选未修饰的名称,但仍可以使用 C# 中的 P/Invoke 调用修饰函数名称。为此,请在调用函数时包含完全修饰的名称。
以上是为什么 C DLL 导出的函数名称有时会被修饰,如何导出未修饰的名称?的详细内容。更多信息请关注PHP中文网其他相关文章!