调用我的CLR项目时,KernelBase.dll出现未处理的异常

Unhandled Exception at KernelBase.dll when Invoking my CLR Project

本文关键字:未处理 异常 dll KernelBase CLR 我的 项目 调用      更新时间:2023-10-16

我得到这个异常:

中0x75374B32(KernelBase.dll)处出现未处理的异常LogLoaderUnmanaged.exe:0xE0434352(参数:0x80070002,0x00000000,0x00000000、0x00000000和0x74040000)。

当我使用以下代码(Application.exe类型项目的一部分)调用CLR项目时:

int _tmain(int argc, _TCHAR* argv[])
{
    _tprintf_s(_T("Press enter to start logging messages."));
    _getch();
    std::string app("Application");
    std::string domain("Domain");
    std::string message("Message");
    UnmanagedLoggerClient::LogError(Debug, app.c_str(), domain.c_str(), message.c_str());
    _tprintf_s(_T("Done."));
}

错误发生在对LogError的调用上,LogError在我的CLR DLL头中定义如下:

#ifdef UNMANAGEDLOGGERCLIENT_EXPORTS
#define WIN32PROJECT_API __declspec(dllexport)
#else
#define WIN32PROJECT_API __declspec(dllimport)
#endif
enum UnmanagedLogLevel
{
    Debug = 0,
    Error = 1
};
static class WIN32PROJECT_API UnmanagedLoggerClient
{
public:
    static void LogError (UnmanagedLogLevel level, const char* app, const char* domain, const char* message);
};

在实现中,方法非常简单:

void UnmanagedLoggerClient::LogError(UnmanagedLogLevel level, const char* app, const char* domain, const char* message)
{
    LoggerClient::LogLevel logLevel = static_cast<LoggerClient::LogLevel>(level);
    LoggerClient::Logger::LogError(logLevel, gcnew String(app), gcnew String(domain), gcnew String(message), DateTime::Now);
}

你知道为什么会这样吗?我不是一个真正的C++爱好者,我在网上搜索这个问题时也没有找到任何有用的信息。非常感谢您的意见!

您使用了一种非常脆弱的方式来初始化CLR,因此诊断很差。异常诊断中有一个"找不到文件"错误代码,错误代码0x80070002。

您成功启动了CLR,异常代码是托管异常,但找不到文件。确保所有可执行文件都与EXE位于同一目录中。使用SysInternals的ProcMon如果没有帮助,你会看到它在搜索文件却找不到。