RuntimeHelpers.PrepareConstrainedRegions Yöntem
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Dikkat
The Constrained Execution Region (CER) feature is not supported.
Bir kod gövdesini kısıtlanmış yürütme bölgesi (CER) olarak tanımlar.
public:
static void PrepareConstrainedRegions();
[System.Obsolete("The Constrained Execution Region (CER) feature is not supported.", DiagnosticId="SYSLIB0004", UrlFormat="https://aka.ms/dotnet-warnings/{0}")]
public static void PrepareConstrainedRegions ();
[System.Security.SecurityCritical]
public static void PrepareConstrainedRegions ();
public static void PrepareConstrainedRegions ();
[<System.Obsolete("The Constrained Execution Region (CER) feature is not supported.", DiagnosticId="SYSLIB0004", UrlFormat="https://aka.ms/dotnet-warnings/{0}")>]
static member PrepareConstrainedRegions : unit -> unit
[<System.Security.SecurityCritical>]
static member PrepareConstrainedRegions : unit -> unit
static member PrepareConstrainedRegions : unit -> unit
Public Shared Sub PrepareConstrainedRegions ()
- Öznitelikler
Örnekler
Aşağıdaki örnekte yöntemini kullanarak tanıtıcıların güvenilir bir şekilde nasıl ayarlanacağı gösterilmektedir PrepareConstrainedRegions . Bir tanıtıcıyı önceden var olan belirli bir tanıtıcıya güvenilir bir şekilde ayarlamak için, yerel tanıtıcının ayrılmasını ve bu tanıtıcının bir SafeHandle nesne içindeki sonraki kaydının atomik olduğundan emin olmanız gerekir. Bu işlemler arasındaki herhangi bir hata (iş parçacığı durdurma veya bellek dışı özel durum gibi) yerel tanıtıcının sızdırılmasına neden olur. Tutamacın PrepareConstrainedRegions sızdırılmadığından emin olmak için yöntemini kullanabilirsiniz.
[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
Açıklamalar
Derleyiciler, , finally
ve fault
bloklarını kısıtlanmış yürütme bölgeleri (CER) olarak işaretlemek catch
için bu yöntemi kullanır. Kısıtlanmış bölge olarak işaretlenen kodun yalnızca güçlü güvenilirlik sözleşmelerine sahip diğer kodları çağırması gerekir. Hataları işlemeye hazır olmadığı sürece hazır olmayan veya güvenilir olmayan yöntemlere sanal çağrılar ayırmamalı veya yapmamalıdır.
yöntemine yapılan çağrı ile try
blok arasında dışında NOP
ara dil opcode'larına PrepareConstrainedRegions izin verilmediğini unutmayın. CER'ler hakkında daha fazla bilgi için ad alanında sınıflara System.Runtime.ConstrainedExecution bakın.
yöntemi kullanılarak PrepareConstrainedRegions işaretlenmiş CER'ler bloktan try
bir StackOverflowException oluşturulduğunda mükemmel çalışmaz. Daha fazla bilgi için yöntemine ExecuteCodeWithGuaranteedCleanup bakın.
PrepareConstrainedRegions yöntemi yöntemini çağırırProbeForSufficientStack.