次の方法で共有


CloseTrace 関数 (evntrace.h)

CloseTrace 関数は、OpenTrace で作成されたトレース処理セッションを閉じます。

構文

ETW_APP_DECLSPEC_DEPRECATED ULONG WMIAPI CloseTrace(
  [in] TRACEHANDLE TraceHandle
);

パラメーター

[in] TraceHandle

閉じるトレース処理セッションを処理します。 OpenTrace 関数は、このハンドルを返します。

戻り値

関数が成功した場合、戻り値は ERROR_SUCCESS です。

関数が失敗した場合、戻り値は システム エラー コードの 1 つです。 一般的なエラーとその原因を次に示します。

  • ERROR_INVALID_HANDLE

    次のいずれかが当てはまります。

    • TraceHandle0 です
    • TraceHandleINVALID_PROCESSTRACE_HANDLE
    • TraceHandle は有効なハンドルではありません。
  • ERROR_BUSY

    Windows Vista より前のバージョンでは、 ProcessTrace 関数が完了するまでトレースを閉じることができません。

  • ERROR_CTX_CLOSE_PENDING

    呼び出しに成功しました。 ProcessTrace 関数は、バッファー内のすべてのリアルタイム イベントを処理した後に停止します (新しいイベントは受信しません)。

解説

コンシューマーはこの関数を呼び出して、 OpenTrace によって返されるトレース ハンドルを閉じます。

重要

StartTrace によって返されるトレース ハンドルを閉じるには、この関数を使用しないでください。

ログ ファイルからイベントを処理する場合は、 ProcessTrace 関数が戻った後にのみこの関数を呼び出します。 ただし、リアルタイム イベントを処理している場合は、 ProcessTrace が返される前にこの関数を呼び出すことができます。 (トレース処理を停止するもう 1 つの方法は、 BufferCallback から FALSE を返す方法です)。

ProcessTrace が返される前にこの関数を呼び出すと、CloseTrace 関数はERROR_CTX_CLOSE_PENDINGを返します。 ERROR_CTX_CLOSE_PENDINGコードは、 CloseTrace 関数の呼び出しが成功したことを示します。 ProcessTrace 関数は、以前にキューに登録されたすべてのイベントを処理した後にイベントの処理を停止します (CloseTrace 関数を呼び出した後、 ProcessTrace は新しいイベントを受信しません)。 CloseTrace 関数は、BufferCallbackEventCallback、または EventClassCallback コールバックから呼び出すことができます。

Windows Vista より前:CloseTrace は、ProcessTrace が返された後にのみ呼び出すことができます。

CloseTrace を使用する例については、「TDH を使用したイベント データの取得」を参照してください。

要件

   
サポートされている最小のクライアント Windows 2000 Professional [デスクトップ アプリ |UWP アプリ]
サポートされている最小のサーバー Windows 2000 Server [デスクトップ アプリ |UWP アプリ]
対象プラットフォーム Windows
ヘッダー evntrace.h
Library Windows 8.1および Windows Server 2012 R2 の Sechost.lib。Windows 8、Windows Server 2012、Windows 7、Windows Server 2008 R2、Windows Server 2008、Windows Vista、Windows XP 上の Advapi32.lib
[DLL] Windows 8.1および Windows Server 2012 R2 の Sechost.dll。Windows 8、Windows Server 2012、Windows 7、Windows Server 2008 R2、Windows Server 2008、Windows Vista、Windows XP での Advapi32.dll

関連項目

OpenTrace

ProcessTrace