0

我得到这个例外:

LogLoaderUnmanaged.exe 中 0x75374B32 (KernelBase.dll) 处未处理的异常: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 的调用,它在我的 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++ 人,我还没有找到任何有用的信息来在线搜索这个问题。非常感谢您的任何意见!

4

1 回答 1

5

您正在使用一种非常脆弱的方式来初始化 CLR,因此诊断效果很差。在您的异常诊断中显示“找不到文件”错误代码,错误代码 0x80070002。

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

于 2013-06-25T19:31:09.613 回答