5

次のコードがあります。

  //mydll.cpp
    #include <Windows.h>
    #include <io.h>

    #define STDOUT_FILEDESC 1

    class MYSTDOUT {
        bool shouldClose;
        bool isBuffered;
    public:
        MYSTDOUT(bool buf = true, bool cl = true) 
            : isBuffered(buf),
              shouldClose(cl) 
        {}
        ~MYSTDOUT() {
            if (shouldClose) {
                close(STDOUT_FILEDESC);
            }
        }
    };

    __declspec(dllexport) void* mydll_init_stdout()
    {
        static MYSTDOUT outs;
        return &outs;
    }
//test_dll.cpp
#include <stdio.h>
#include <stdlib.h>
#include <Windows.h>
#include <io.h>


typedef void* (__cdecl *MYPROC)(void);


int main(void)
{
  int fd;
  void *pstdout;

  MYPROC init_stdout;
  HMODULE handle = LoadLibrary(TEXT("mydll.dll")); 

  init_stdout = (MYPROC)GetProcAddress(handle,"mydll_init_stdout");//NULL

  FreeLibrary((HMODULE) handle);
  return 0;
}

init_stdout が NULL であることがわかりました。何が問題になる可能性がありますか? ハンドルはOKです(NULLではありません)ありがとう

4

2 に答える 2

14

それは名前のマングリングによるものです。

エクスポートされた関数を次のようにラップする必要がありますextern "C"

extern "C"
{
    __declspec(dllexport) void* mydll_init_stdout()
    {
        static MYSTDOUT outs;
        return &outs;
    }
}
于 2012-04-20T16:53:47.470 に答える
10

Dependency Walker を確認してください。または、マングルされた C++ 名でエクスポートされているdumpbin /exportsことがわかります。mydll_init_stdoutそのため、GetProcAddress呼び出しは失敗します。

extern "C"マングリングを停止するために使用します。

extern "C" 
{
    __declspec(dllexport) void* mydll_init_stdout()
    {
        static MYSTDOUT outs;
        return &outs;
    }
}
于 2012-04-20T16:52:54.220 に答える