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."));
}

エラーは、CLR DLL のヘッダーで次のように定義されている LogError の呼び出しにあります。

#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 に答える