从托管 C++/CLI 线程调用静态 C# 方法
Calling a static C# method from a managed C++/CLI thread
我似乎无法调用静态 C# 方法。
我目前有 2 个 DLL,我将它们注入到一个古老的遗留应用程序中,然后执行一个静态方法,如下面的代码所示:
Module.cs
using System;
namespace Debugger
{
public static class Module
{
public static void Initialize()
{
Console.WriteLine("YES");
}
}
}
dllmain.cpp
#include "stdafx.h"
#include <windows.h>
#pragma once
#pragma managed
using namespace System;
using namespace System::Reflection;
using namespace Debugger;
DWORD WINAPI MainThread(LPVOID param)
{
AllocConsole();
Console::WriteLine("Test");
Debugger::Module::Initialize();
FreeLibraryAndExitThread((HMODULE)param, 0);
return 0;
}
#pragma unmanaged
HMODULE hModule;
BOOL APIENTRY DllMain(HINSTANCE hInstance, DWORD reason, LPVOID reserved)
{
switch (reason)
{
case DLL_PROCESS_ATTACH:
CreateThread(0, 0, MainThread, hModule, 0, 0);
break;
case DLL_PROCESS_DETACH:
FreeLibrary(hModule);
break;
}
return true;
}
结果:我打开了控制台,弹出了 'Test' 消息,但 'YES' 没有弹出 - 相反,应用程序崩溃了。
将 DLL 移动到与我注入的可执行文件相同的文件夹解决了这个问题。
我似乎无法调用静态 C# 方法。
我目前有 2 个 DLL,我将它们注入到一个古老的遗留应用程序中,然后执行一个静态方法,如下面的代码所示:
Module.cs
using System;
namespace Debugger
{
public static class Module
{
public static void Initialize()
{
Console.WriteLine("YES");
}
}
}
dllmain.cpp
#include "stdafx.h"
#include <windows.h>
#pragma once
#pragma managed
using namespace System;
using namespace System::Reflection;
using namespace Debugger;
DWORD WINAPI MainThread(LPVOID param)
{
AllocConsole();
Console::WriteLine("Test");
Debugger::Module::Initialize();
FreeLibraryAndExitThread((HMODULE)param, 0);
return 0;
}
#pragma unmanaged
HMODULE hModule;
BOOL APIENTRY DllMain(HINSTANCE hInstance, DWORD reason, LPVOID reserved)
{
switch (reason)
{
case DLL_PROCESS_ATTACH:
CreateThread(0, 0, MainThread, hModule, 0, 0);
break;
case DLL_PROCESS_DETACH:
FreeLibrary(hModule);
break;
}
return true;
}
结果:我打开了控制台,弹出了 'Test' 消息,但 'YES' 没有弹出 - 相反,应用程序崩溃了。
将 DLL 移动到与我注入的可执行文件相同的文件夹解决了这个问题。