次の方法で共有


ICLRSyncManager::GetMonitorOwner メソッド

更新 : 2007 年 11 月

指定した Cookie によって識別されるモニタを所有する IHostTask インスタンスを取得します。

HRESULT GetMonitorOwner (
    [in]  SIZE_T     cookie,
    [out] IHostTask *ppOwnerHostTask
);

パラメータ

  • cookie
    [入力] モニタに関連付けられた Cookie。

  • ppOwnerHostTask
    [出力] 現在モニタを所有している IHostTask へのポインタ。タスクが所有権を持たない場合は null。

戻り値

HRESULT

説明

S_OK

GetMonitorOwner が正常に終了しました。

HOST_E_CLRNOTAVAILABLE

CLR がプロセスに読み込まれていません。または、CLR がマネージ コードを実行できない状態か、呼び出しを正常に処理できない状態にあります。

HOST_E_TIMEOUT

呼び出しがタイムアウトしました。

HOST_E_NOT_OWNER

呼び出し元がロックを所有していません。

HOST_E_ABANDONED

ブロックされたスレッドまたはファイバが待機しているイベントがキャンセルされました。

E_FAIL

未知の重大エラーが発生しました。メソッドから E_FAIL が返される場合、プロセス内で CLR を使用することはできません。ホスト メソッドへの後続の呼び出しで、HOST_E_CLRNOTAVAILABLE が返されます。

解説

ホストは、通常、GetMonitorOwner を、デッドロック検出機構の中で呼び出します。Cookie は、IHostSyncManager::CreateMonitorEvent 呼び出しを使用して作成されるときにモニタに関連付けられます。

ms164422.alert_note(ja-jp,VS.90).gifメモ :

モニタの基になるイベントを解放するための呼び出しは、このメソッドの呼び出しがそのモニタに関連付けられている Cookie で現在有効である場合に、ブロックする可能性があります (ただしデッドロックは発生しません)。他のタスクも、このモニタの取得を試みた場合はブロックします。

GetMonitorOwner は、常にすぐに返されます。また、CreateMonitorEvent 呼び出しの後であればいつでも呼び出すことができます。ホストは、タスクがそのイベントを待機していない限り、待機する必要はありません。

必要条件

プラットフォーム : 「.NET Framework システム要件」を参照

ヘッダー : MSCorEE.idl

ライブラリ : MSCorEE.dll にリソースとして格納されていること

.NET Framework のバージョン : 3.5 SP1、3.5、3.0 SP1、3.0、2.0 SP1、2.0

参照

参照

ICLRSyncManager

IHostSyncManager