【发布时间】:2013-06-25 18:19: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 的调用,它在我的 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++ 人,我还没有找到任何有用的信息来在线搜索这个问题。非常感谢您的任何意见!
【问题讨论】:
-
@HansPassant - 你是个英雄。我觉得很愚蠢,不检查 0x80070002 代表什么。这正是它不起作用的原因。输出目录与所有依赖项所在的二进制目录不同。请将您的答案作为解决方案发布,以便我将其设置为正确答案!
标签: c++ exception clr unmanaged managed