(依赖沃克)缺少函数上的显式类型
(Dependency Walker) missing explicit type on function
提前为菜鸟错误道歉。这是我在这里的第一个问题。首先,一些背景:
我正在尝试使用依赖 walker 为程序创建一个模块,以查找我没有库或任何源代码的.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 &)
前两个函数显然采用浮点数或空度并返回浮点数或空数。我得到了一个类似的函数,使用如下内容:
HINSTANCE THEDLL = LoadLibrary("C:\dllFolder\theDll.dll");
typedef float (*quxType)(void);
quxType qux = (quxType)GetProcAddress(THEDLL, "quxMangledName");
所以这些都不是问题。
现在,列表中的第三个看起来像另一个采用 void 的函数,但它没有显式返回类型。这是否意味着我应该只为它使用隐式类型,它是 void,还是它不是一个真正的函数?如果没有,那是什么?
我不知道如何处理第四个。是否可以在没有关联的 .h 文件的情况下进行处理?
我环顾四周,但我找不到任何关于当函数看起来不像具有显式返回类型的普通函数时该怎么做的信息。尽管使用的代码与我用来让函数在类似.dll中工作的代码基本相同,但当我尝试在此处使用函数 #2 时,我不断遇到访问冲突崩溃(我真的只需要函数 #2(。所以我猜测.dll需要更多信息或需要先初始化一些东西,这就是为什么我对列表中的其他人感兴趣。
我意识到这是一个复杂的问题,所以可能不会有一个"正确答案"的解决方案来让它工作,但是如果我犯了任何明显的错误,或者如果有任何关于如何解决这个问题的一般建议(甚至是依赖沃克的替代方案(,让我知道。
第三个是 bar 的默认构造函数。第四个是柱线的复制赋值运算符。
我认为您需要先实例化该类,以便调用第二个方法。否则,将使用无效的"this"调用该方法,从而导致访问冲突。
问题是你如何实例化它?如果可以找到在 DLL 中返回条形的工厂函数,则可以尝试使用它。
如果您没有看到工厂函数并且没有 lib 文件,则可以参考此处有关如何从 DLL 创建 lib 的答案:如何在具有 .dll 文件和头文件时制作 .lib 文件
您还需要为类创建具有正确顺序和成员类型的头文件。这样你就不必使用 LoadLibrary 和 GetProcAddress,只需像往常一样使用该类即可。
不过,您仍然可以在没有 lib 和标头的情况下使用 LoadLibrary 和 GetProcAddress,但此博客展示了如何手动分配内存、调用构造函数、获取对象并传递该对象以调用方法:http://recxltd.blogspot.com/2012/02/working-with-c-dll-exports-without.html
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 将C++子类成员函数(虚拟实现)传递给 C 类型函数指针
- C++ 这里有一个返回 (24) 的布尔返回类型函数
- 使用SFINAE来检测void返回类型函数的存在
- 使用此类型函数有什么优势
- 为什么此函数通过类型函数指针调用后,呼叫明智地行为
- 如何使用无类型函数指针调用C++成员函数
- 模板返回类型函数如何在C++中工作
- 具有通用类型函数的动态库[C ]
- 如何在返回类型函数模板的专用化中使用派生类型?( "couldn't infer template argument" )
- Bon appetit :从 int 返回类型函数在 main() 中打印字符串
- 对于需要其他模板参数的类型函数的部分模板专业化
- c++错误的参数类型-函数指针
- 延迟评估模板类型函数
- 在引用或指针返回类型函数上输入
- 具有指针数据类型的非类型函数模板参数
- STL中使用的C++自定义比较类型(函数谓词与较少结构)
- C++模板基类的非类型函数模板的 using 声明
- 字符串到类型函数,模板专用化使调用统一
- 自由类型函数可以接受 Unicode 文件名吗?