【问题标题】:Why does this C program infinitely loop?为什么这个 C 程序会无限循环?
【发布时间】:2013-10-20 00:26:05
【问题描述】:

我写了一个 DLL 文件,我可以将它注入到另一个进程中。一旦注入,它应该创建一个消息框。它似乎创建了无限数量的消息框并且我的计算机崩溃了。有任何想法吗?另外,DLLIMPORT 和 DWORD WINAPI 有什么区别? Main 应该是 DLLIMPORT 还是其他?

dllmain.c

/* Replace "dll.h" with the name of your header */
#include "dll.h"
#include <windows.h>

DLLIMPORT void HelloWorld() {
    MessageBox(0,"Hello World from DLL!\n","Hi",MB_ICONINFORMATION);
}

int main() {
    MessageBox(0,"Hello World from DLL!\n","Hi",MB_ICONINFORMATION);
}

DWORD WINAPI Main(LPVOID lpParam) {
    main();
    return S_OK;
}

BOOL WINAPI DllMain(
    HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved) {
    switch(fdwReason) {
        case DLL_PROCESS_ATTACH:
        break;

        case DLL_PROCESS_DETACH:
        break;

        case DLL_THREAD_ATTACH:
        DisableThreadLibraryCalls(hinstDLL);
        CreateThread(NULL, 0, &Main, NULL, 0, NULL);
        break;

        case DLL_THREAD_DETACH:
        break;
    }

    return TRUE;
}

dll.h

#ifndef _DLL_H_
#define _DLL_H_

#if BUILDING_DLL
#define DLLIMPORT __declspec(dllexport)
#else
#define DLLIMPORT __declspec(dllimport)
#endif

DLLIMPORT void HelloWorld();

#endif

【问题讨论】:

  • 也许 DLL_THREAD_ATTACH 中的 CreateThread() 会导致另一个线程附加事件,该事件调用 DllMain(),从而开始递归。这只是我的猜测。我对纯 Win32 了解不多。

标签: c winapi dll


【解决方案1】:

当DLL附加到进程而不是线程时执行线程:

...
        case DLL_PROCESS_ATTACH:
        DisableThreadLibraryCalls(hinstDLL);
        CreateThread(NULL, 0, Main, NULL, 0, NULL);
        break;

        case DLL_PROCESS_DETACH:
        break;

        case DLL_THREAD_ATTACH:
        break;

        case DLL_THREAD_DETACH:
        break;
...

检查你传递给CreateThread的回调,它应该是Main而不是&amp;Main,它已经是指针了。

【讨论】:

  • @BSH:为什么 Main 已经是一个指针了?如果我理解正确,Main 是一个 DWORD。因此,它是一个无符号整数。
  • @user2899050 Main 是指向函数的指针、地址,因此这里没有必要使用&amp;Main。老实说,我不知道DWORD 来自哪里,但Main 不是DWORD,它是一个函数指针。如果参考大小,地址是 32 位,DWORD 是 32 位类型,但在 64 位系统上不是这样,DWORD 是 32 位,Main 地址是 64 位。
  • 我相信在获取函数地址时,Main 和 &Main 是等价的。取其他任何东西的地址是另一回事。
猜你喜欢
  • 2017-11-08
  • 1970-01-01
  • 2011-08-13
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2020-08-08
相关资源
最近更新 更多