1

为菜鸟的错误提前道歉。这是我在这里的第一个问题。首先,一些背景:

我正在尝试为使用依赖项walker 的程序创建一个模块,以在我没有lib 或任何源代码的.dll 中查找C++ 函数。您也可以假设我无法从原始开发人员那里获得支持。基本上,我检查了另一个访问它的文件,以查看使其工作的最小功能。这是输出的未修饰名称的示例:

void foo::bar::baz(float)
float foo::bar::qux(void)
foo::bar::bar(void)
class foo::bar & foo::bar::operator=(class foo::bar const &)

前两个函数显然采用 float 或 void 并返回 float 或 void。我得到了一个类似的功能,使用类似的东西:

HINSTANCE THEDLL = LoadLibrary("C:\\dllFolder\\theDll.dll");
typedef float (*quxType)(void);
quxType qux = (quxType)GetProcAddress(THEDLL, "quxMangledName");

所以这些都不是问题。

现在,列表中的第三个看起来像另一个接受 void 的函数,但它没有明确的返回类型。这是否意味着我应该只使用隐式类型,它是无效的,还是不是真正的函数?如果不是,那是什么?

我不知道如何处理第四个。甚至可以在没有关联的 .h 文件的情况下处理吗?

我环顾四周,但找不到任何关于当函数看起来不像具有显式返回类型的普通函数时该怎么做的信息。尽管使用了与在类似 .dll 中工作的函数基本相同的代码,但当我在这里尝试使用函数 #2 时(我真的只需要函数 #2),我仍然遇到访问冲突崩溃。所以我猜测 .dll 需要更多信息或需要先初始化一些东西,这就是为什么我对列表中的其他内容感兴趣。

我意识到这是一个复杂的问题,所以可能不会有一个“正确答案”的解决方案来让它工作,但是如果我犯了任何明显的错误,或者有任何关于如何解决问题的一般性建议(甚至依赖walker的替代品),让我知道。

4

1 回答 1

0

第三个是 bar 的默认构造函数。第 4 个是 bar 的复制赋值运算符。

我认为您需要先实例化该类,才能调用第二种方法。否则,将使用导致访问冲突的无效“this”调用该方法。

问题是你如何实例化它?如果你能在DLL中找到一个返回bar的工厂函数,你可以尝试使用它。

如果您没有看到工厂函数并且没有 lib 文件,您可以在此处参考有关如何从 DLL 创建 lib 的答案:How to make a .lib file when have a .dll file and a头文件

您还需要为类创建头文件,其中包含正确的成员顺序和类型。这样您就不必使用 LoadLibrary 和 GetProcAddress,只需照常使用该类即可。

您仍然可以在没有 lib 和标头的情况下使用 LoadLibrary 和 GetProcAddress,此博客展示了如何手动分配内存、调用构造函数、获取对象并将该对象传递给调用方法:http ://recxltd.blogspot.com/2012/ 02/working-with-c-dll-exports-without.html

于 2013-09-29T03:26:18.117 回答