我正在编写一个MFC项目,该项目尝试调用DLL中的函数,该函数将返回字符串中的一些信息。 DLL中的函数如下:
int GetInfo(char* Info)
如果成功,该函数将返回0。信息将在字符串参数中返回。调用例程如下:
typedef int (WINAPI *FUNC1)(char* szInfo);
HINSTANCE hinstLib;
FUNC1 GetInfo;
char szInfo[50];
hinstLib = LoadLibrary(TEXT("DevInfo.dll"));
// If the handle is valid, try to get the function address.
if (hinstLib != NULL)
{
GetInfo = (FUNC1) GetProcAddress(hinstLib, "GetInfo");
// If the function address is valid, call the function.
if (NULL != GetInfo)
{
if((GetInfo) (szInfo)) // Error here!!
{
AfxMessageBox(_T("Error Reading"));
}
}
FreeLibrary(hinstLib);
}
此代码在编译和链接时没有错误。执行时,它将返回错误"访问冲突执行位置0x00000000"在上述位置。有人可以建议吗?
答案 0 :(得分:2)
您尝试写入(或取消引用)NULL指针。当您检查调用代码中的所有可能的NULL时,错误很可能是在您的被调用代码中。
如果您检查了被调用的代码,但无法找到空引用异常的原因,请考虑您可能错过了正确匹配调用约定。函数指针的类型应与库中的类型完全相同:
对于int GetInfo(char* Info)
,typedef应为typedef int (*FUNC1)(char* szInfo);
答案 1 :(得分:1)
也可能有超过50个字符被写入缓冲区(szInfo):
char szInfo [50];