如何在没有类型转换的情况下使用getProcAddress()

how to use getProcAddress() without type cast?

本文关键字:getProcAddress 情况下 类型转换      更新时间:2023-10-16

我正在尝试使用getprocaddress查找变量的地址。但我在这方面遇到了问题。问题是,我在循环中一个接一个地将变量的名称存储在char-buff[100]中。那一次我不知道变量的类型。那么如何在没有类型转换的情况下使用它呢。我尝试使用void*ptr来避免类型转换。我得到ptr的值为零。

void *ptr;
HMODULE hdl;
char buff[100];
char word[100];
char ch1;
int     total_item=0;
META_INFO_FILE=fopen("META.txt","r");
do {
ch1 = fscanf(META_INFO_FILE,"%s",word); 
if ((word[0]== '_'))
{   
strcpy(META_buff,word+1);
hdl = GetModuleHandle (NULL); // handle of executable
ptr =GetProcAddress (hdl, META_buff);
total_item++;
} while (ch1 != EOF); 

感谢

好吧,您的ptr为NULL,因为您找不到名称。这与铸造完全无关。(例如,你可能需要摆弄DLLExport之类的东西来使你的符号可见)如果这是你的问题,那么我们就到此为止了。[顺便说一句,在你的例子中,buff看起来像一个局部变量。根据定义,它们不能从DLL导出,因为这种变量只有在函数"在活动调用堆栈中"时才可用。你不能真正将符号导出到导出时不存在的变量…

但我怀疑你在问"如果我能找到这个符号,我该如何使用它"。

简短的回答是"你不能那样做"。

长篇大论的答案是"你不能那样做",但有一点可能的解决方案。您必须以某种方式在META_INFO_FILE中编码您拥有的数据类型。至少如果您想做任何事情,而不是对结果调用memcpy(ptr, somestuff, somesize)

我还认为可能有更好的方法来做到这一点。至少,如果你正在处理的是你自己的代码——如果你正在"修补"别人的代码,那你就太丢脸了。

例如,你可以引入你自己的符号,其中有关于它是什么类型的信息,等等

例如:

enum Type { CHAR_TYPE, INT_TYPE, /* more types here ... */ }
struct 
{
char *name;
Type type;
char *size;
void *ptr;
}
mysymbols [] = 
{
{ "buff", CHAR_TYPE, sizeof(buff), &buff },
{ "other", INT_TYPE, sizeof(other), &other },
};

现在,您可以搜索该列表,然后使用"开关"转换为正确的类型。