/CLRSUPPORTLASTERROR (PInvoke 呼び出しの最終エラー コードの保持)

既定でオンになっている /CLRSUPPORTLASTERROR を指定すると、P/Invoke メカニズムを介して呼び出される関数の最終エラー コードが保持されます。これにより、/clr を指定してコンパイルしたコードから DLL のネイティブ関数を呼び出すことができます。

構文

/CLRSUPPORTLASTERROR{:NO | SYSTEMDLL}

解説

最終エラー コードを保持すると、パフォーマンスが低下します。 最終エラー コードを保持する場合のパフォーマンスへの影響を回避したい場合は、/CLRSUPPORTLASTERROR:NO を指定してリンクします。

/CLRSUPPORTLASTERROR:SYSTEMDLL を指定してリンクすると、パフォーマンスへの影響を最小限に抑えることができます。この場合、システム DLL 内の関数の最終エラー コードのみが保持されます。

Note

最終エラーの保持は、同じモジュール内で、CLR コードによって使用されるアンマネージド関数ではサポートされていません。

Visual Studio 開発環境でこのリンカー オプションを設定するには

  1. プロジェクトの [プロパティ ページ] ダイアログ ボックスを開きます。 詳細については、Visual Studio での C++ コンパイラとビルド プロパティの設定に関するページを参照してください。

  2. [構成プロパティ]>[リンカー]>[コマンド ライン] プロパティ ページを選択します。

  3. [追加オプション] ボックスにオプションを入力します。

このリンカーをコードから設定するには

次の例では、最終エラーを変更する 1 つのエクスポートされた関数を含むネイティブ DLL を定義しています。

// CLRSUPPORTLASTERROR_dll.cpp
// compile with: /LD
#include <windows.h>
#include <math.h>

#pragma unmanaged
__declspec(dllexport) double MySqrt(__int64 n) {
   SetLastError(DWORD(-1));
   return sqrt(double(n));
}

次の例では、この DLL を使って、/CLRSUPPORTLASTERROR の使用方法を示しています。

// CLRSUPPORTLASTERROR_client.cpp
// compile with: /clr CLRSUPPORTLASTERROR_dll.lib /link /clrsupportlasterror:systemdll
// processor: x86
#include <windows.h>
#include <wininet.h>
#include <stdio.h>
#include <math.h>

#pragma comment(lib, "wininet.lib")

double MySqrt(__int64 n);

#pragma managed
int main() {
   double   d = 0.0;
   __int64 n = 65;
   HANDLE  hGroup = NULL;
   GROUPID groupID;
   DWORD   dwSet = 127, dwGet = 37;

   SetLastError(dwSet);
   d = MySqrt(n);
   dwGet = GetLastError();

   if (dwGet == DWORD(-1))
      printf_s("GetLastError for application call succeeded (%d).\n",
             dwGet);
   else
      printf_s("GetLastError for application call failed (%d).\n",
             dwGet);

   hGroup = FindFirstUrlCacheGroup(0, CACHEGROUP_SEARCH_ALL,
                           0, 0, &groupID, 0);
   dwGet = GetLastError();
   if (dwGet == 183)
      printf_s("GetLastError for system call succeeded (%d).\n",
             dwGet);
   else
      printf_s("GetLastError for system call failed (%d).\n",
             dwGet);
}
GetLastError for application call failed (127).
GetLastError for system call succeeded (183).

関連項目

MSVC リンカーのリファレンス
MSVC リンカー オプション