RuntimeHelpers.PrepareConstrainedRegions メソッド
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
コードの本文を制約付き実行領域 (CER) として指定します。
public:
static void PrepareConstrainedRegions();
public static void PrepareConstrainedRegions();
[System.Security.SecurityCritical]
public static void PrepareConstrainedRegions();
static member PrepareConstrainedRegions : unit -> unit
[<System.Security.SecurityCritical>]
static member PrepareConstrainedRegions : unit -> unit
Public Shared Sub PrepareConstrainedRegions ()
- 属性
例
次の例は、 PrepareConstrainedRegions メソッドを使用してハンドルを確実に設定する方法を示しています。 指定した既存のハンドルにハンドルを確実に設定するには、ネイティブ ハンドルの割り当てと、 SafeHandle オブジェクト内でのそのハンドルの後続の記録がアトミックであることを確認する必要があります。 これらの操作 (スレッドの中止やメモリ不足の例外など) の間でエラーが発生すると、ネイティブ ハンドルがリークされます。 PrepareConstrainedRegions メソッドを使用して、ハンドルがリークしないようにすることができます。
[StructLayout(LayoutKind.Sequential)]
struct MyStruct
{
public IntPtr m_outputHandle;
}
sealed class MySafeHandle : SafeHandle
{
// Called by P/Invoke when returning SafeHandles
public MySafeHandle()
: base(IntPtr.Zero, true)
{
}
public MySafeHandle AllocateHandle()
{
// Allocate SafeHandle first to avoid failure later.
MySafeHandle sh = new MySafeHandle();
RuntimeHelpers.PrepareConstrainedRegions();
try { }
finally
{
MyStruct myStruct = new MyStruct();
NativeAllocateHandle(ref myStruct);
sh.SetHandle(myStruct.m_outputHandle);
}
return sh;
}
<StructLayout(LayoutKind.Sequential)> _
Structure MyStruct
Public m_outputHandle As IntPtr
End Structure 'MyStruct
NotInheritable Class MySafeHandle
Inherits SafeHandle
' Called by P/Invoke when returning SafeHandles
Public Sub New()
MyBase.New(IntPtr.Zero, True)
End Sub
Public Function AllocateHandle() As MySafeHandle
' Allocate SafeHandle first to avoid failure later.
Dim sh As New MySafeHandle()
RuntimeHelpers.PrepareConstrainedRegions()
Try
Finally
Dim myStruct As New MyStruct()
NativeAllocateHandle(myStruct)
sh.SetHandle(myStruct.m_outputHandle)
End Try
Return sh
End Function
注釈
コンパイラは、このメソッドを使用して、 catch、 finally、および fault ブロックを制約付き実行領域 (CER) としてマークします。 制約付きリージョンとしてマークされているコードは、信頼性の高いコントラクトを持つ他のコードのみを呼び出す必要があります。 エラーを処理する準備が整っていない限り、準備されていないメソッドや信頼性の低いメソッドを割り当てたり、仮想呼び出しを行ったりしないでください。
NOPを除く中間言語オペコードは、PrepareConstrainedRegions メソッドの呼び出しと try ブロックの間では許可されません。 CER の詳細については、 System.Runtime.ConstrainedExecution 名前空間のクラスを参照してください。
try ブロックからStackOverflowExceptionが生成された場合、PrepareConstrainedRegions メソッドを使用してマークされた CER は完全には機能しません。 詳細については、 ExecuteCodeWithGuaranteedCleanup メソッドを参照してください。
PrepareConstrainedRegions メソッドは、ProbeForSufficientStack メソッドを呼び出します。