次の方法で共有


IHostTaskManager::LeaveRuntime メソッド

現在実行中のタスクが共通言語ランタイム (CLR) から移動し、アンマネージド コードに入ることをホストに通知します。

重要

IHostTaskManager::EnterRuntime への対応する呼び出しにより、現在実行中のタスクがマネージド コードに再度入ることをホストに通知します。

構文

HRESULT LeaveRuntime (  
    [in] SIZE_T target  
);  

パラメーター

target
[in] 呼び出されるアンマネージド関数の、マップされた移植可能な実行可能ファイル内のアドレス。

戻り値

HRESULT 説明
S_OK LeaveRuntime が正常に返されました。
HOST_E_CLRNOTAVAILABLE CLR がプロセスに読み込まれていないか、CLR がマネージド コードを実行できないまたは呼び出しを正常に処理できない状態です。
HOST_E_TIMEOUT 呼び出しがタイムアウトになりました。
HOST_E_NOT_OWNER 呼び出し元がロックを所有していません。
HOST_E_ABANDONED ブロックされたスレッドまたはファイバーが待機しているときに、イベントが取り消されました。
E_FAIL 原因不明の致命的なエラーが発生しました。 メソッドにより E_FAIL が返されると、そのプロセス内で CLR が使用できなくなります。 後続のホスティング メソッドの呼び出しでは HOST_E_CLRNOTAVAILABLE が返されます。
E_OUTOFMEMORY メモリ不足のため、要求された割り当てを完了できません。

解説

アンマネージド コードとの間の呼び出しシーケンスは入れ子にすることができます。 たとえば、次の一覧は、LeaveRuntimeIHostTaskManager::ReverseEnterRuntimeIHostTaskManager::ReverseLeaveRuntimeIHostTaskManager::EnterRuntime に対する一連の呼び出しによって、 ホストから入れ子になったレイヤーを識別できるようにする仮定の状況を示しています。

操作 対応するメソッド呼び出し
マネージド Visual Basic 実行可能ファイルでは、プラットフォーム呼び出しを使用して C で記述されたアンマネージド関数を呼び出します。 IHostTaskManager::LeaveRuntime
アンマネージド C 関数により、C# で記述されたマネージド DLL 内のメソッドが呼び出されます。 IHostTaskManager::ReverseEnterRuntime
マネージド C# 関数により、こちらでもプラットフォーム呼び出しを使用して、C で記述された別のアンマネージド関数が呼び出されます。 IHostTaskManager::LeaveRuntime
2 番目のアンマネージド関数により、C# 関数に実行が返されます。 IHostTaskManager::EnterRuntime
C# 関数により、最初のアンマネージド関数に実行が返されます。 IHostTaskManager::ReverseLeaveRuntime
最初のアンマネージド関数により、実行が Visual Basic プログラムに返されます。 IHostTaskManager::EnterRuntime

必要条件

:システム要件」を参照してください。

ヘッダー: MSCorEE.h

ライブラリ: MSCorEE.dll にリソースとして含まれます

.NET Framework のバージョン: 2.0 以降で使用可能

関連項目